关于杭电acm 为什么提交上去老提示 wrong answer 求高手解答

#include<stdio.h>#include<stdlib.h>intmain(){inta[100005],sum[100005];intn,i=1,num,j,... #include<stdio.h>
#include<stdlib.h>
int main()
{
int a[100005],sum[100005];
int n,i=1,num,j,begin=1,end=1,max;
scanf("%d",&n);
if(n>20||n<0)
printf("error\n");
while(n--)
{
scanf("%d",&num);
for(j=1;j<=num;j++)
{
scanf("%d",&a[j]);
if(a[j]>1000||a[j]<-1000)
printf("error!");
}

max=sum[1]=a[1];
for(j=2;j<=num;j++)
{
if(sum[j-1]<0)
{
sum[j]=a[j];
begin=j;
if(max<sum[j])
{
max=sum[j];
end=j;
}
}
else
{
sum[j]=sum[j-1]+a[j];
if(sum[j]>max)
{
max=sum[j];
end=j;
}
}
}
printf("Case %d\n",i);
printf("%d %d %d\n",max,begin,end);
if(i<=n)
printf("\n");
}
return 0;
}
展开
 我来答
porker2008
2012-05-15 · TA获得超过1.4万个赞
知道大有可为答主
回答量:7066
采纳率:62%
帮助的人:1.1亿
展开全部
#include<stdio.h>
#include<stdlib.h>
int main()
{
int a[100005],sum[100005];
int n,i=1,num,j,begin=1,end=1,max,temp;
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%d",&num);
for(j=1;j<=num;j++)
{
scanf("%d",&a[j]);
}

max=sum[1]=a[1];
temp = 1;
begin = end = 1;
for(j=2;j<=num;j++)
{
if(sum[j-1]<0)
{
sum[j]=a[j];
temp=j;
}
else
{
sum[j]=sum[j-1]+a[j];
}
if(max<sum[j])
{
begin = temp;
max=sum[j];
end=j;
}
}
printf("Case %d:\n",i);
printf("%d %d %d\n",max,begin,end);
if(i<n)
printf("\n");
}
return 0;
}
追问
请问 temp在这里起到什么作用,我测试了几组数据都没有问题?麻烦了,thx
追答
temp的作用是记录临时的起点,只有在max<sum[j]的情况下才需要把begin更新为temp的值
参考下面的Case
1
3 3 -4 2
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式