杭电ACM 1003题 一直无法AC,求解答原因

代码#include<iostream.h>intmain(){inti,n,sum=0,a[100001],num,j,t,m,max=0,sta=1,fin=1;ci... 代码
#include<iostream.h>
int main()
{
int i,n,sum=0,a[100001],num,j,t,m,max=0,sta=1,fin=1;
cin>>n;
for(i=1;i<=n;i++)
{
cin>>num;
for(j=1;j<=num;j++)
{
cin>>a[j];
}
max=a[1];
for(t=1;t<=num;t++)
for(m=t,sum=0;m<=num;m++)
{
sum+=a[m];
if(sum>max)
{
sta=t,fin=m;
max=sum;
}
if(sum<0)
{
t=m;
sum=0;
break;
}
}
cout<<"Case "<<i<<":"<<endl;
cout<<max<<' '<<sta<<' '<<fin<<endl;
if(i!=n)
cout<<endl;
sta=0,fin=0,max=0;
}
}
展开
 我来答
porker2008
2012-05-25 · TA获得超过1.4万个赞
知道大有可为答主
回答量:7066
采纳率:62%
帮助的人:1.1亿
展开全部
#include<iostream>
using namespace std;

int main()
{
int i,n,sum=0,a[100001],num,j,t,m,max=0,sta=1,fin=1;
cin>>n;
for(i=1;i<=n;i++)
{
cin>>num;
for(j=1;j<=num;j++)
{
cin>>a[j];
}
max=a[1];
for(t=1;t<=num;t++)
for(m=t,sum=0;m<=num;m++)
{
sum+=a[m];
if(sum>max)
{
sta=t,fin=m;
max=sum;
}
if(sum<0)
{
t=m;
sum=0;
break;
}
}
cout<<"Case "<<i<<":"<<endl;
cout<<max<<' '<<sta<<' '<<fin<<endl;
if(i!=n)
cout<<endl;
sta=1,fin=1,max=0; // sta, fin应该初始化为1
}
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式