求助,为什么这道题要用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不是整型吗?为什么要给它定义成浮点型呢?希望有懂的大佬解答一下,感激不尽! 可以,但是原型是
double pow(double base, double exponent) claws0n 发表于 2018-10-27 16:26
可以,但是原型是
double pow(double base, double exponent)
小甲鱼的答案为什么要把那个result变量定义为浮点型呢? CNWX45 发表于 2018-10-27 16:34
小甲鱼的答案为什么要把那个result变量定义为浮点型呢?
他爽~ claws0n 发表于 2018-10-27 16:37
他爽~
我主要是不懂为什么不用int整型呢,它的运算结果不是整型吗,但是我用int的时候结果又是错的,用double浮点型运算结果就是对的,想了大半天还是没想懂。 CNWX45 发表于 2018-10-27 16:41
我主要是不懂为什么不用int整型呢,它的运算结果不是整型吗,但是我用int的时候结果又是错的,用double浮 ...
函数返回的是 double,你用 int 会报错,除非你强制转型
int result = (int)pow(i, 5); claws0n 发表于 2018-10-27 16:26
可以,但是原型是
double pow(double base, double exponent)
这也可以用 int 但是这种几次方的数字得出来回太大int可能装不下 claws0n 发表于 2018-10-27 16:49
函数返回的是 double,你用 int 会报错,除非你强制转型
int result = (int)pow(i, 5);
大概明白了,谢谢你的回答! 唐沉沉 发表于 2018-10-27 16:55
这也可以用 int 但是这种几次方的数字得出来回太大int可能装不下
我想我大概懂了,谢谢你的回答!
页:
[1]