%o——将整型数据int以8进制输出
%d——将整型数据int以10进制输出。
%x——将整型数据int以16进制输出
%f——单精度浮点型数据 float 的格式符。
%lf——双精度浮点型数据 double 的格式符。(与 %f 的区别在于:1、能表示数的范围不同。2、有效数字位数不同。3、代表的数据类型不同。)
%e——将浮点型数据用科学计数法表示
#include<stdio.h>
int main()
{
double b = 100000000000000000;
printf("%e\n", b); //1.000000e+17————e后面的数字就是代表10的几次方
printf("%lf", b);//100000000000000000.000000
return 0;
}
%c——字符型数据 char 的格式符
%s——字符串型数据。遇空格、制表符或换行符结束(%c是只输出一个字符型数据,但%s是输出整个字符串。PS:详见下图)
char a;
char b[20];
scanf("%c",&a); //只能输入一个字符。
scanf("%s",b); //可以输入一串不超过20字符的字符串。
%p ——将数据的地址输出。
接下来介绍对格式符的“修饰”
%2d——保证每个数据站2个空格的大小,不足则在前面补一个空格
%02d——保证每个数据站2个空格的大小,不足则在前面补一个“0”
%-2d——保证每个数据站2个空格的大小,不足则在后面补一个空格(这两种一般是为了将输出美化一下)
%-02d——保证每个数据站2个空格的大小,不足则在后面补一个“0”
%.2f——保留小数点后两位