调用pow运算 -1 出错
画重点:不知道大家有没有看出来
pow(2, 62) - 1
结果居然是偶数。。。。
果然。。
我的数学是体育老师教的。。。。。。{:10_266:}{:10_266:}{:10_266:}
数字太大,数据溢出问题,小事 claws0n 发表于 2018-8-12 14:43
数字太大,数据溢出问题,小事
可是我只算到了62次幂,理论最大值不是2^64 - 1 吗?不应该溢出啊 本帖最后由 claws0n 于 2018-8-12 16:15 编辑
幻风帝影 发表于 2018-8-12 14:52
可是我只算到了62次幂,理论最大值不是2^64 - 1 吗?不应该溢出啊
绝对溢出,pow(double x, double y); long 已经超出 double 的范围了
a= 4294967925// 这个应该也是错的答案,但是至少是奇数
这个要看编译器了 claws0n 发表于 2018-8-12 16:10
绝对溢出,pow(double x, double y); long 已经超出 double 的范围了
a= 4294967925// 这个应该也是 ...
如果2^62已经溢出
那么在课后作业里计算麦子的那个结果就应该是错误的:
也就是说
课后作业的答案错了
对吗?
claws0n 发表于 2018-8-12 16:10
绝对溢出,pow(double x, double y); long 已经超出 double 的范围了
a= 4294967925// 这个应该也是 ...
抱着这个疑问
我换了一种算法
没有去调用pow
代码如下:
现在我们来看看运行结果
它是这个样子的
和课后作业里面的没有区别:
这也就证明了
2^62其实没有溢出
因为在课后作业的算法里
是要算到2^63的
没有错吧?
幻风帝影 发表于 2018-8-12 22:27
如果2^62已经溢出
那么在课后作业里计算麦子的那个结果就应该是错误的:
也就是说
{:9_240:} 我不知道,没有做过~~
答案有至少 15 位数吗?
C 语言的 pow 最多支持到 double 而已。你自己写一个比较看 幻风帝影 发表于 2018-8-12 22:47
抱着这个疑问
我换了一种算法
没有去调用pow
其实 long long 之类的,是要看机器的,每个机器与编译器的配合会导致不一样的情况。这是我需要做的修改,才能实现。你可以去找,真正的叙述是 short <= int <= long <= long long 是大于等于,需要看系统
#include <stdio.h>
#include <math.h>
int main()
{
unsigned long long a;
a = (unsigned long long)pow(2,62)-1;
printf("a = %llu\n", a);
return 0;
} 幻风帝影 发表于 2018-8-12 22:47
抱着这个疑问
我换了一种算法
没有去调用pow
其实 long long 之类的,是要看机器的,每个机器与编译器的配合会导致不一样的情况。这是我需要做的修改,才能实现。你可以去找,真正的叙述是 short <= int <= long <= long long 是大于等于,需要看系统
#include <stdio.h>
#include <math.h>
int main()
{
unsigned long long a;
a = (unsigned long long)pow(2,62)-1;
printf("a = %llu\n", a);
return 0;
} claws0n 发表于 2018-8-12 23:00
我不知道,没有做过~~
答案有至少 15 位数吗?
麦子那个就是比较啊,有没有调用pow,结果都是一样的。 claws0n 发表于 2018-8-13 00:08
其实 long long 之类的,是要看机器的,每个机器与编译器的配合会导致不一样的情况。这是我需要做的修改 ...
我明白了,谢谢
页:
[1]