【C++语言训练】舍罕王的失算 (精确解代码

博客讲述了关于舍罕王的失算问题,即棋盘上格子填麦粒的故事。文章指出,虽然问题简单,但网上的解法各异,存在精度误差。博主提供了C++代码实现,确保得出精确结果18446744073709551615,以此为读者展示正确求解方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

相传国际象棋是古印度舍罕王的宰相达依尔发明的.舍罕王十分喜爱象棋,决定让宰相自己选择何种赏赐.这位聪明的宰相指着8*8共64格的象棋说:陛下,请您赏给我一些麦子吧.就在棋盘的第1格放1粒,第2格放2粒,第三格放4粒,以后每一格都是比前一格的两倍,依此放完棋盘一64格,我就感激不尽了.舍罕王让人扛了一袋麦子,他要兑现他的许诺.
请问,国王要兑现他的许诺共要多少粒麦子赏赐他的宰相?

输入描述:

输出描述:

18446744073709551615

这道题其实没有什么难度,但是在网上看了一圈,为什么这个题的题解各个博客写的五花八门:
有用double求成18446744073709552000,也有用int 求成 18446744073709551616的…

贴个C++解,抛砖引玉

#include<iostream>
using namespace std;
int main()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值