C语言中实型变量的问题

2025-03-19 08:41:00
推荐回答(4个)
回答1:

double类型的数据输入最好采用%lg,而且我采用你的输入方式没有得到错误的结果;
整型数可以自动转换为实型,而实型转换为整型就要进行强制转换,将丢掉小数位,强制转换的方法是(int)x;
pow(x,y)是一个内联函数,编译的时候进行替换操作,所以要进行计算一定要用一个中间变量来存储这个结果,不能直接打印pow(...)的结果

回答2:

pow(1,100)=1.000000
没错,再自己看看程序

#include
#include
int main()
{
printf("%f\n", pow(10,2));
printf("%lf\n", pow(10,2));
printf("%ld\n", (long)pow(10,2));
printf("%d\n", (int)pow(10,2));
return 0;
}
结果都是100或100.00000,
还是你程序有问题吧?

回答3:

先乘以100
然后用ceil函数进行4舍5入处理,得到的数再取整就可以了。

回答4:

书上的基础,long 的取值范围-2147483648~2147483647 double的比特数是8个,只能取前8位,后面数据溢出~~~