关于pow()函数和数据类型
#include <stdio.h>#include <math.h>
int main(void)
{
int result1, result2;
int m = 5;
result1 = pow(m, m+1);
result2 = pow(5, 6);
printf("result1 = %d, result2 = %d\n", result1, result2);
return 0;
}
结果:
result1 = 15624
result2 = 15625
怎么会这样?
我试过,如果全部改成float类型就对了,是因为实参的参数类型和形参的参数类型不匹配导致的么?
求解答,谢谢各位啦! 本帖最后由 DT_Nelson 于 2019-8-3 12:02 编辑
看这篇函数快查,pow返回值类型是double
https://fishc.com.cn/forum.php?mod=viewthread&tid=67234&extra=page%3D1%26filter%3Dtypeid%26typeid%3D583
#include <stdio.h>
#include <math.h>
int main(int argc, const char *argv[]){
double result1, result2;
int m = 5;
result1 = pow(m, m+1);
result2 = pow(5, 6);
printf("result1 = %.0lf, result2 = %.0lf\n", result1, result2);
return 0;
} 向下取舍
并不是四舍五入 DT_Nelson 发表于 2019-8-3 11:59
看这篇函数快查,pow返回值类型是double
https://fishc.com.cn/forum.php?mod=viewthread&tid=67234&extra ...
都改成double型是可以的。
但是为什么用整型,输入整型常量5, 6能得到正确答案? 本帖最后由 DT_Nelson 于 2019-8-3 17:11 编辑
风雨张先知 发表于 2019-8-3 16:47
都改成double型是可以的。
但是为什么用整型,输入整型常量5, 6能得到正确答案?
这真是见了鬼了,在我的编译器上结果都不一样
DT_Nelson 发表于 2019-8-3 17:09
这真是见了鬼了,在我的编译器上结果都不一样
神奇。。。
页:
[1]