我这个用2的0次方到63次方想加,但答案输出到和问题的答案不一样,这个问题的答案是18446744073709551614但我这个有点太大了,我又想不出来我代码哪里有问题
棋盘放麦子问题,一共64格
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
5条回答 默认 最新
- apples_kk 2023-03-30 10:27关注
因为题目的结果已经超过long表示的最大值了,long最大值:9,223,372,036,854,775,807
使用BigInteger存储结果便可,代码修改如下:import java.math.BigInteger; public class TwoPowerSum { public static void main(String[] args) { BigInteger sum = BigInteger.ZERO; for (int i = 0; i <= 63; i++) { BigInteger base = BigInteger.valueOf(2); BigInteger pow = base.pow(i); sum = sum.add(pow); } System.out.println(sum); } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥100 角动量包络面如何用MATLAB绘制
- ¥15 merge函数占用内存过大
- ¥15 Revit2020下载问题
- ¥15 使用EMD去噪处理RML2016数据集时候的原理
- ¥15 神经网络预测均方误差很小 但是图像上看着差别太大
- ¥15 单片机无法进入HAL_TIM_PWM_PulseFinishedCallback回调函数
- ¥15 Oracle中如何从clob类型截取特定字符串后面的字符
- ¥15 想通过pywinauto自动电机应用程序按钮,但是找不到应用程序按钮信息
- ¥15 如何在炒股软件中,爬到我想看的日k线
- ¥15 seatunnel 怎么配置Elasticsearch