CHENZEPENG 发表于 2021-5-30 11:48:09

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

tian1234 发表于 2021-5-31 18:00:47

结果应该是2   2.5   2.5,整数/整数 = 整数,强转也没用了

wp231957 发表于 2021-5-30 11:53:41

这代码,惨不忍睹啊

CHENZEPENG 发表于 2021-5-30 12:01:33

复制的{:10_266:}

万千只cnm 发表于 2021-5-30 12:41:44

%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的控制输出.

han125416866 发表于 2021-5-31 23:20:40

结果2   2.52.5 只要弄懂强制转换过程就好C是面向过程的不要刻意去纠结重要的是其中的过程否则会影响你学习进程
页: [1]
查看完整版本: printf