CNWX45 发表于 2018-10-27 16:11:26

求助,为什么这道题要用double而不是int呢?

本帖最后由 CNWX45 于 2018-10-27 17:43 编辑

1.按以下要求编写程序。
要求用户输入一个十进制整数(按下回车完成输入)
计算出该整数值的五次方
打印计算结果

#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;
}

我自己做的时候,我把result这个变量定义为int类型,但是打印出来运算结果是错的,我看了一下答案是把这个变量定义为double类型,我有点想不懂,result不是整型吗?为什么要给它定义成浮点型呢?希望有懂的大佬解答一下,感激不尽!

claws0n 发表于 2018-10-27 16:26:29

可以,但是原型是
double pow(double base, double exponent)

CNWX45 发表于 2018-10-27 16:34:58

claws0n 发表于 2018-10-27 16:26
可以,但是原型是
double pow(double base, double exponent)

小甲鱼的答案为什么要把那个result变量定义为浮点型呢?

claws0n 发表于 2018-10-27 16:37:22

CNWX45 发表于 2018-10-27 16:34
小甲鱼的答案为什么要把那个result变量定义为浮点型呢?

他爽~

CNWX45 发表于 2018-10-27 16:41:25

claws0n 发表于 2018-10-27 16:37
他爽~

我主要是不懂为什么不用int整型呢,它的运算结果不是整型吗,但是我用int的时候结果又是错的,用double浮点型运算结果就是对的,想了大半天还是没想懂。

claws0n 发表于 2018-10-27 16:49:09

CNWX45 发表于 2018-10-27 16:41
我主要是不懂为什么不用int整型呢,它的运算结果不是整型吗,但是我用int的时候结果又是错的,用double浮 ...

函数返回的是 double,你用 int 会报错,除非你强制转型
int result = (int)pow(i, 5);

唐沉沉 发表于 2018-10-27 16:55:18

claws0n 发表于 2018-10-27 16:26
可以,但是原型是
double pow(double base, double exponent)

这也可以用   int   但是这种几次方的数字得出来回太大int可能装不下

CNWX45 发表于 2018-10-27 17:40:20

claws0n 发表于 2018-10-27 16:49
函数返回的是 double,你用 int 会报错,除非你强制转型
int result = (int)pow(i, 5);

大概明白了,谢谢你的回答!

CNWX45 发表于 2018-10-27 17:41:29

唐沉沉 发表于 2018-10-27 16:55
这也可以用   int   但是这种几次方的数字得出来回太大int可能装不下

我想我大概懂了,谢谢你的回答!
页: [1]
查看完整版本: 求助,为什么这道题要用double而不是int呢?