2104205904 发表于 2022-4-4 15:11:31

小甲鱼的课后作业: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类型就不行了?

isdkz 发表于 2022-4-4 15:14:24

你可以换成 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;
}

FK二十一 发表于 2022-4-4 15:45:47

你换成了int,可以理解为装值得容器变小了,实际上是系统分配的内存变小了,这样你在存储一些浮点型数据的时候就不能完全装的下,势必会造成数据的缺失。
所以既然你想用 .2f 即小数点后两位的精度来表达的话,也就合情合理用浮点数float或者double来存储数据了。

texttext 发表于 2022-9-28 11:28:15

同问这道题:我试了一下3.14^5:

int i 改成 float i, 或 double i,
scanf("%d", &i) 改成 scanf("%.2f", &i)
printf (".....%.2f\n", result)   保持不变

结果就算不出来了。也就是说,如果输入是浮点的话,就算不出来。不知道为什么

henkuderen 发表于 2022-9-29 13:34:52

scanf是不可以设置精度的,.2f是非法的
页: [1]
查看完整版本: 小甲鱼的课后作业:S1E7:取值范围