杭电ACm,problem1001的疑问,为什么不能用高斯算法

InputTheinputwillconsistofaseriesofintegersn,oneintegerperline.OutputForeachcase,outp... Input
The input will consist of a series of integers n, one integer per line.

Output
For each case, output SUM(n) in one line, followed by a blank line. You may assume the result will be in the range of 32-bit signed integer.

很疑惑
#include <iostream>
using namespace std;
void main()
{int n;
while(cin>>n)
{
int i,sum=0;
for(i=1;i<=n;i++) sum=sum+i;
cout<<sum<<endl<<endl;
}
}
成功ac但是
#include <iostream>
using namespace std;
void main()
{int n;
while(cin>>n)
{
cout<<n*(n+1)/2<<endl<<endl;
}
}
就老是报错,求教是为何,按照道理结果是一样的啊。
展开
 我来答
DN_海伦泰勒
推荐于2018-04-13 · TA获得超过104个赞
知道答主
回答量:68
采纳率:0%
帮助的人:46.3万
展开全部
因为n很大的时候n*(n+1)的值会溢出。可以判断奇偶然后先做除法。
注意这句:You may assume the result will be in the range of 32-bit signed integer.
要求是你的结果要在32位有符号整型范围内。假设n*(n+1)/2的结果刚好满足32位。但是在做除法前
n*(n+1)的结果就超过了32位。
富港检测技术(东莞)有限公司_
2024-05-27 广告
ISTA3E程序是对相同产品的集合包装的综合模拟性能测试,集合包装件被定义为将一个产品、多个产品或包装件放置在滑板或托盘上,固定在一起或是作为一个单元运输。例如:一台机器由带瓦楞底托的托盘上、瓦楞侧围、顶盖包装,用缠绕膜缠绕在托盘上。用于评... 点击进入详情页
本回答由富港检测技术(东莞)有限公司_提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式