先看題目
Max Sum
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 190877 Accepted Submission(s): 44442
暴力肯定不行,一看就是動態規劃的題目。一維的動態規劃,有兩個點,如果遇到正數,加上去肯定是會變大的,對於一個數是這樣,對於很多個數的和也是一樣,第二點是如果前面的幾個數的和是負數,就要把起始位置改爲負數後的一點。再和前面最大的數比較,若後面有更大的數就改起始位置。
代碼如下
#include <iostream>
using namespace std;
int a[100000];
typedef struct
{
int sum;
int start;
int end;
}result;
result dp(int count)
{
int i;
int max=-9999999;
int k=1;
result res;
res.sum=0;
i=1;
while(i<=count)
{
res.sum+=a[i];
if(res.sum>max)
{
max=res.sum;
res.start=k;
res.end=i;
}
if(res.sum<0)
{
res.sum=0;
k=i+1;
}
i++;
}
res.sum=max;
return res;
}
int main()
{
result res;
int i;
int j=1;
int number;
int count;
cin>>number;
while(number)
{
cin>>count;
for(i=1;i<=count;i++)
{
cin>>a[i];
}
res=dp(count);
if(j!=1)
cout<<endl;
cout<<"Case "<<j<<":"<<endl;
cout<<res.sum<<" "<<res.start<<" "<<res.end<<endl;
number--;
j++;
}
return 0;
}
ac了