小甲鱼的课后作业:S1E7:取值范围
小甲鱼的课后作业:S1E7:取值范围 | 课后测试题及答案#include <stdio.h>
#include <math.h>
int main()
{
int i;
double result;
printf("请输入一个整数:");
scanf("%d", &i);
result = pow(i, 5);
printf("%d的五次方是:%.2f\n", i, result);
return 0;
}
为什么这样定义:
int i;
double result;
把double类型换成int类型就不行了? 你可以换成 int ,不过格式化那里也得改:
#include <stdio.h>
#include <math.h>
int main()
{
int i;
int result;
printf("请输入一个整数:");
scanf("%d", &i);
result = pow(i, 5);
printf("%d的五次方是:%d\n", i, result); // 这里的 %.2f 得改成 %d
return 0;
} 你换成了int,可以理解为装值得容器变小了,实际上是系统分配的内存变小了,这样你在存储一些浮点型数据的时候就不能完全装的下,势必会造成数据的缺失。
所以既然你想用 .2f 即小数点后两位的精度来表达的话,也就合情合理用浮点数float或者double来存储数据了。 同问这道题:我试了一下3.14^5:
int i 改成 float i, 或 double i,
scanf("%d", &i) 改成 scanf("%.2f", &i)
printf (".....%.2f\n", result) 保持不变
结果就算不出来了。也就是说,如果输入是浮点的话,就算不出来。不知道为什么 scanf是不可以设置精度的,.2f是非法的
页:
[1]