printf
1 #include<stdio.h>2 int main(void){
3 int inum1=4, inum2=10;
4 double dnum=4.0;
5 printf("(double)(inum2/inum1)=%g\n",(double)(inum2/inum1));
6 printf("(double)inum2/inum1=%g\n",(double)inum2/inum1);
7 printf("inum2/dnum=%g\n",inum2/dnum);
8 return 0;
9 }
题目上还说了 printf("%g",3.2000);对应的输出为3.2,printf(“%g”,40.0000);对应的输出为40。
输出结果是啊啥?
是这个吗?
2.5
2.5
2.5
结果应该是2 2.5 2.5,整数/整数 = 整数,强转也没用了 这代码,惨不忍睹啊 复制的{:10_266:} %g用来输出实数,它根据数值的大小,自动选f格式或e格式(选择输出时占宽度较小的一种),且不输出无意义的0。即%g是根据结果自动选择科学记数法还是一般的小数记数法
printf("%g\n", 0.00001234);
printf("%g\n", 0.0001234);
printf("%.2g\n", 123.45);
printf("%.2g\n", 23.45);
上面四句输出结果为:
1.234e-05
0.0001234
1.2e+02
23
对于指数小于-4或者大于给定精度的数值,按照%e的控制输出,否则按照%f的控制输出. 结果2 2.52.5 只要弄懂强制转换过程就好C是面向过程的不要刻意去纠结重要的是其中的过程否则会影响你学习进程
页:
[1]