概述
printf的总结
1 #include<stdio.h> 2 #include<string.h> 3 #include <iostream> 4 #include <cmath> 5 #include <iomanip> 6 using namespace std; 7 8 int main() 9 { 10 char c, s[20]; 11 int a=1234; 12 float f=3.141592653589; 13 double x=5.52345678912345678; 14 strcpy(s, "Hello,World"); 15 c='x41'; 16 printf("a=%dn", a);//按照十进制整数格式输出,显示 a=1234 17 printf("a=%d%%n", a);//输出%号 结果 a=1234% 18 printf("a=%6dn", a);//输出6位十进制整数 左边补空格,显示 a= 1234 19 printf("a=%06dn", a);//输出6位十进制整数 左边补0,显示 a=001234 20 printf("a=%2dn", a);//a超过2位,按实际输出 a=1234 21 printf("a=%-6dn", a);///输出6位十进制整数 右边补空格,显示 a=1234 22 printf("f=%fn", f);//浮点数有效数字是7位,结果 f=3.141593 23 printf("f=%6.4fn", f);//输出6列,小数点后4位,结果 f=3.1416 24 printf("new=%0.7fn",2.1);//小数后补0,结果2.1000000 25 printf("x=%lfn", x);//输出长浮点数 x=0.123457 26 printf("x=%18.16lfn", x);//输出18列,小数点后16位,x=0.1234567891234567 27 printf("c=%cn", c); //输出字符 c=A 28 printf("c=%xn", c);//以十六进制输出字符的ASCII码 c=41 29 printf("s[]=%sn", s);//输出数组字符串s[]=Hello,World 30 printf("s[]=%6.9sn", s);//输出最多9个字符的字符串 s[]=Hello,Wor 31 printf("x=%.lfn",x); //四舍五入操作 32 cout<<"x="<<round(x)<<endl;//四舍五入函数 round() 33 cout<<"a="<<setw(3)<<setfill('0')<<28<<endl; 34 cout<<showpoint<<setprecision(8)<<2.1<<endl;//2.100 0000 35 // showpoint 和 setiosflags()还是有点区别的,使用时应注意 36 cout<<setiosflags(ios::fixed) << setprecision(8) <<2.1 <<endl; //2.1000 0000 37 38 return 0; 39 }
编译输出截图如下:
copy一下别人的总结:
格式字符用以指定输出项的数据类型和输出格式。
①d格式:用来输出十进制整数。有以下几种用法:
%d:按整型数据的实际长度输出。
%md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。
%ld:输出长整型数据。
②o格式:以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。
例:
main()
{ int a = -1;
printf("%d, %o", a, a);
}
运行结果:-1,177777
程序解析:-1在内存单元中(以补码形式存放)为(1111111111111111)2,转换为八进制数为(177777)8。
③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格式中较短的一种输出,且不输出无意义的零。
转载于:https://www.cnblogs.com/liugl7/p/4896895.html
最后
以上就是年轻月亮为你收集整理的print输出格式总结的全部内容,希望文章能够帮你解决print输出格式总结所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复