在C语言中,输入使用的是scanf函数,scanf函数的格式为scanf(格式控制,地址列表),如scanf("%d"&a)。
输出使用的是printf()函数,printf函数的格式为printf(格式控制,输出表列),如printf("%d\n",a)。在输出时可以在"%"和字母之间插进数字表示最大场宽。可以根据需要输出数字的位数来决定“%”前的数值。
如:%3d表示输出3位整型数, 不够3位右对齐。
%9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为7,小数点占一位, 不够9位右对齐。
%8s 表示输出8个字符的字符串, 不够8个字符右对齐。
扩展资料
C语言输入输出时的规则:
一、格式说明符个数与输入数据个数不相等的情况:
当我们输入数据时,只要没有按回车键,所输入的数据都还存放在缓冲区,并没有存入变量中。按【Enter】键后,scanf()函数才会从缓冲区中取走数据。缓冲区是一个先进先出的队列,即取走数据的时候,遵循先输入的数据先取走的原则。
scanf函数的格式说明符有几个就要取几次数据,只要碰到格式说明符就必须把数据取走,至于是不是要把取走的数据存放起来,就得看数据列表中的数据个数。没取完的数据继续留在缓冲区中。
二、宽度输出的情况:
1、在%和格式字符之间加入一个整数来控制输出数据所占宽度
2、在%和格式字符f之间加入一个“整数1. 整数2”来控制输出数据的格式。
整数1:整个输出数据占的总宽度
整数2:输出实数的小数部分的个数
注意:先用整数2处理小数部分,再用整数1处理整个数据,包括已处理好的小数部分
三、宽度输入的情况:
宽度输入指的是在%和格式说明符d之间加入一个整数。如:scanf("%2d", &x);
注意:
1、%d与%1d是不同的,它们具有不同的含义。
2、 当宽度小于数据的实际宽度时,截取指定宽度的部分作为一个数进入缓冲区,再将剩余部分作为另一个数放入缓冲区。
参考资料来源:百度百科——scanf
百度百科——printf()
常用的格式符还有 %n.mf -- 浮点数, 总长n ,m位小数 。(可不用,取默认长)
%c -- 单字符, %s -- 字串 ,%t -- 固定下一区(8 位)
注:printf()中每个格式符都要与同类型的变量挂钩,一个对一个。
理解原样照印:设 x= 3 y=5
printf(“x=%d y=2*x-1=%d”,x,y);
输出 为 x=3 y=2*x-1=5
%3d 是根据自己的需要决定的。例如输出数为1到3位,你考虑各行输出数据对齐,
你可以用 %3d, 例如:
int a=1,b=18,c=123;
int d=23,e=35,f=56;
printf("%3d %3d %3d\n",a,b,c);
printf("%3d %3d %3d\n",d,e,f);
白白1 空白18 空123
白23空白35空白56
------
%d 是默认格式。
----
输入%3d 在特殊情况下用,一般用 %d 灵活。
特殊的例子:
int a,b;
scanf("%3d%3d",&a,&b); // 输入数据之间无空隔,例如: 123456
printf("%d %d",a,b); // 输出 123 456
如果不用%3d%3d, 123456 就会被看成一个数, 不处理成3位3位。
格式的完整版是-0m.n(l或h)+格式字符 我们平常用的都是缺省格式很多位置没填,你首先要弄明白格式的意思。。。。
-是对齐方式,0是空位的填补方式(缺省表示填空格否则是填0) m是整个数占用字符个数,n是小数点后的位数,l或h是长度标识,l就是long的意思,长整形或双精度,h就是short的意思用于短整型(不填就是单精度或整形)。。。d就是输出格式可以是16进制10进制,8进制,你用的d就是10进制的意思。。。。
3d就是m处填3,格式字符是10进制,所以意思就是3位十进制数,如果大于3位多出的会不输出。。。
%d是直接输出,%3d是要占三个字符的位置,
比如要输出百度这两个字
你输出%d就是直接输出个:百度
输出%3d就是输出: 百度
就是这个意思。
希望回答能帮到你
%3d用的时候一般是让程序美观