风雨张先知 发表于 2019-8-3 10:59:55

关于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 11:59:04

本帖最后由 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;
}

AmosAlbert 发表于 2019-8-3 16:45:13

向下取舍
并不是四舍五入

风雨张先知 发表于 2019-8-3 16:47:22

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:09:52

本帖最后由 DT_Nelson 于 2019-8-3 17:11 编辑

风雨张先知 发表于 2019-8-3 16:47
都改成double型是可以的。
但是为什么用整型,输入整型常量5, 6能得到正确答案?

这真是见了鬼了,在我的编译器上结果都不一样

风雨张先知 发表于 2019-8-4 09:28:04

DT_Nelson 发表于 2019-8-3 17:09
这真是见了鬼了,在我的编译器上结果都不一样

神奇。。。
页: [1]
查看完整版本: 关于pow()函数和数据类型