萌新刚学C语言。想问一下这里哪里错了?

就是高中的数学课本上那个国际象棋棋盘那个题吧,按理来说第N个格子的麦粒应该是2的N-1次方。第N个格子的麦粒加上之前的麦粒总和应该为2的N次方再减一。为什么我写的代码里面... 就是高中的数学课本上那个国际象棋棋盘那个题吧,按理来说第N个格子的麦粒应该是2的N-1次方。 第N个格子的麦粒加上之前的麦粒总和应该为2的N次方 再减一。 为什么我写的代码里面第54个开始它的结果就不正确了呢????求指教哪里错了。 展开
 我来答
处摇胼手胝足
2018-06-11 · TA获得超过294个赞
知道小有建树答主
回答量:488
采纳率:83%
帮助的人:164万
展开全部
double 最高有效们52位,因为double是用64位表达的,有12位表示符号和2的幂,也就是说当有效位数到达2的52次方,就会出来精度偏差。程序没有错,如果想精确表达数值,超过52位有效值不能直接采用double运算,必须自己编写数组来表达算法。
追问
我好像把double理解成了长整形了。。。哈哈。。尴尬
时空魔法
2018-06-11 · TA获得超过249个赞
知道小有建树答主
回答量:424
采纳率:50%
帮助的人:77万
展开全部
卧槽叻。 一模一样的代码。 答案居然不一样
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式