题目地址:http://pat.zju.edu.cn/contests/pat-a-practise/1007
求最大子串和的问题。
代码如下:
//#include "StdAfx.h"
#include<stdio.h>
#include<iostream>
using namespace std;
int main()
{
//freopen("D://test.txt","r",stdin);
int num[10010];
int k,i,sum;
int st,end,max,tst;
bool f;
scanf("%d",&k);
for(i=0;i<k;i++)
scanf("%d",&num[i]);
max=-1;
sum=0;
st=end=num[0];
tst=num[0];
for(i=0;i<k;i++){
if(sum<0){
sum=0;
tst=num[i];
}
sum=sum+num[i];
if(sum>max){
max=sum;
st=tst;
end=num[i];
}
}
f=false;
for(i=0;i<k;i++)
if(num[i]>=0){
f=true;
break;
}
if(!f){
max=0;
st=num[0];
end=num[k-1];
}
printf("%d %d %d\n",max,st,end);
return 0;
}