c语言数组逆序输出中输出的形式是%.f就能实现四舍五入,为什么?

C语言的printf输出格式_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
C语言的printf输出格式
上传于||暂无简介
阅读已结束,如果下载本文需要使用1下载券
想免费下载本文?
定制HR最喜欢的简历
你可能喜欢今天看啥 热点:
C语言的printf输出格式控制,printf输出格式C语言的printf输出格式控制&
printf大家都耳熟能详,但是能真正将其用法弄透的估计很少见。&转一篇,改天整理。&
1.转换说明符&
%a(%A)&&&&&浮点数、十六进制数字和p-(P-)记数法(C99)&
%c&&&&&&&&&字符&
%d&&&&&&&&&有符号十进制整数&
%f&&&&&&&&&浮点数(包括float和doulbe)&
%e(%E)&&&&&浮点数指数输出[e-(E-)记数法]&
%g(%G)&&&&&浮点数不显无意义的零"0"&
%i & & & &&有符号十进制整数(与%d相同)&
%u&&&&&&&&&无符号十进制整数&%o&&&&&&&&&八进制整数&
%x(%X)&&&&&十六进制整数0f(0F)&&&e.g.&&&0x1234&
%p&&&&&&&&&指针&
%s&&&&&&&&&字符串&
%%&&&&&&&&&输出字符%&
左对齐:"-"&&&比如:"%-20s"&
右对齐:"+"&&&比如:"%+20s"&
空格:若符号为正,则显示空格,负则显示"-"&&比如:"%&6.2f" & & &&
#:对c,s,d,u类无影响;对o类,在输出时加前缀o;对x类,在输出时加前缀0x;对e,g,f&类当结果有小数时才给出小数点。&
printf的格式控制的完整格式:&
%&-&0&m.n&l或h&格式字符 &
下面对组成格式说明的各项加以说明:
①%:表示格式说明的起始符号,不可缺少。&
②-:有-表示左对齐输出,如省略表示右对齐输出。&
③0:有0表示指定空位填0,如省略表示指定空位不填。&
④m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。N指精度。用于说明输出的实型数的小数位数。未指定n时,隐含的精度为n=6位。&
⑤l或h:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。
&格式字符 &
格式字符用以指定输出项的数据类型和输出格式。&
①d格式:用来输出十进制整数。有以下几种用法:&
%d:按整型数据的实际长度输出。&
%md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。&
%ld:输出长整型数据。&
②o格式:以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用&%mo&格式输出。&
main()&{&int&a&=&-1;&
printf("%d,&%o",&a,&a);&}&
运行结果:-1,177777&
程序解析:-1在内存单元中(以补码形式存放)为(1111)2,转换为八进制数为(。&
③x格式:以无符号十六进制形式输出整数。对长整型可以用"%lx"格式输出。同样也可以指定字段宽度用"%mx"格式输出。&
④u格式:以无符号十进制形式输出整数。对长整型可以用"%lu"格式输出。同样也可以指定字段宽度用&%mu&格式输出。&
⑤c格式:输出一个字符。&
⑥s格式:用来输出一个串。有几中用法&
%s:例如:printf("%s",&"CHINA")输出"CHINA"字符串(不包括双引号)。&
%ms:输出的字符串占m列,如字符串本身长度大于m,则突破获m的限制,将字符串全部输出。若串长小于m,则左补空格。&
%-ms:如果串长小于m,则在m列范围内,字符串向左靠,右补空格。&
%m.ns:输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。&
%-m.ns:其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n&m,则自动取n值,即保证n个字符正常输出。&
⑦f格式:用来输出实数(包括单、双精度),以小数形式输出。有以下几种用法:&%f:不指定宽度,整数部分全部输出并输出6位小数。&
%m.nf:输出共占m列,其中有n位小数,如数值宽度小于m左端补空格。&&%-m.nf:输出共占n列,其中有n位小数,如数值宽度小于m右端补空格。&
⑧e格式:以指数形式输出实数。可用以下形式:&
%e:数字部分(又称尾数)输出6位小数,指数部分占5位或4位。&
%m.ne和%-m.ne:m、n和&-&字符含义与前相同。此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。&
⑨g格式:自动选f格式或e格式中较短的一种输出,且不输出无意义的零。&
---------------------------------------&
关于printf函数的进一步说明:&
如果想输出字符"%",则应该在&格式控制&字符串中用连续两个%表示,如:&
printf("%f%%",&1.0/3);&
输出0.333333%。&
对于单精度数,使用%f格式符输出时,仅前7位是有效数字,小数6位.&
对于双精度数,使用%lf格式符输出时,前16位是有效数字,小数6位.&
对于m.n的格式还可以用如下方法表示&char&ch[20];&
printf("%*.*s\n",m,n,ch);&
前边的*定义的是总的宽度,后边的*定义的是输出的个数。分别对应外面的参数m和n&。我想这种方法的好处是可以在语句之外对参数m和n赋值,从而控制输出格式。&&今天(06.6.9)又看到一种输出格式&%n&可以将所输出字符串的长度值赋绐一个变量,&见下例:&
printf("hello&world%n",&&slen);&执行后变量被赋值为11。
输出8字节(64位)的整数时 & 输出格式应为%llu & %lld & &%llo等等;
int main(int argc , char *argv[])
  time_t sec = 4775807;  //即sec = 0x7
  printf("time = %lld\n" , sec);
  printf("time = %llx\n" , sec);
  printf("time = %0*llx\n" , 2 * sizeof(time_t) , sec);
 time =&4775807
 time = 7fffffffffffffff
& &time = 7fffffffffffffff
printf(&输出格式&,变量名);这就是最简单的用法#include &stdio.h&void main(){printf(&please input a number:\n&);scanf(&%d&,&a);printf(&%d\n&,a);}最简单的关于printf例子
printf(&%5.3f&,125);按语法规则,%f 用于float数,125 要写成浮点数:printf(&%5.3f&,125.0);
5.3 意思是场宽5个字符,小数点下3位,场宽不够则按实际需要输出应打印出 125.000printf(&%3.1f&,25.796);
小数点下1位,后面的4舍5入,打印 25.8 printf(&%5.2f&,25.796);
小数点下2位,后面的4舍5入, 打印 25.80 printf(&%5.2f&,1.25);
小数点下2位,场宽5个字符(包括数字,小数点,负数还要包括-号)。场宽不够则按实际需要输出,太宽则填空白。printf(&%5.2f&,125. );
小数点下2位,场宽5个字符, 125.00
, 场宽不够则按实际需要输出,太宽则填空白。
相关搜索:
相关阅读:
相关频道:
&&&&&&&&&&&&&&&&
C语言最近更新

我要回帖

更多关于 c语言数组逆序输出 的文章

 

随机推荐