【博主赠言】
博主弱爆了,在学习动态规划的专题,注意到了这道题目,可是。。。可是。。。我跪了,求最大连续子序列和我可以用dp解出来,可是引入的参数太多,需要考虑负数甚至全负数的情况。在求长度的时候我就完全混乱了,所以我转载了大神的解题报告。莫鄙视
【测试数据】
在HDU discuss里面的测试数据,给大家测试用
4 0 0 2 0 —— 2 1 3 6 2 7 -9 5 4 3 —— 12 1 6 4 0 0 -1 0 —— 0 1 1 7 -1 -2 -3 -2 -5 -1 -2 —— -1 1 1 6 -1 -2 -3 1 2 3 —— 6 4 6 5 -3 -2 -1 -2 -3 —— -1 3 3
转载自:http://www.cnblogs.com/zhourongqing/archive/2012/04/08/2438202.html
【算法分析】
算法分析:求最大字段和,d[i]表示
已
i 结尾(字段和中包含 i )在 a[1..i] 上的最大和,d[i]=(d[i-1]+a[i]>a[i])?d[i-1]+a[i]:a[i];
max = {d[i],1<=i<=n} ;
【code】
#include<iostream>
#define N 100010
using namespace std;
int a[N],d[N];
int main()
{
int test,n,i,max,k,f,e;
cin>>test;
k=1;
while(test--)
{
cin>>n;
for(i=1;i<=n;i++)
cin>>a[i];
d[1]=a[1];
for(i=2;i<=n;i++)
{
if(d[i-1]<0) d[i]=a[i];
else d[i]=d[i-1]+a[i];
}
max=d[1];e=1;
for(i=2;i<=n;i++)
{
if(max<d[i])
{
max=d[i];e=i;
}
}
int t=0;
f=e;
for(i=e;i>0;i--)
{
t=t+a[i];
if(t==max) f=i;
}
cout<<"Case "<<k++<<":"<<endl<<max<<" "<<f<<" "<<e<<endl;
if(test) cout<<endl;
}
return 0;
}
【只处理最大和不处理位置】纯dp
#include<iostream>
using namespace std;
int main(void){
int t;
cin>>t;
while(t--){
int n;
cin>>n;
int *arr = new int [n+1];
int *dp = new int [n+1];
for(int i=1;i<=n;i++)
cin>>arr[i];
int temp = 0;
dp[0] = -100000;
for(int i=1;i<=n;i++){
if(temp < 0){
if(arr[i] > dp[i-1]){
dp[i] = arr[i];
}
else
dp[i] = dp[i-1];
temp = arr[i];
continue;
}
temp += arr[i];
if(temp > dp[i-1]){
dp[i] = temp ;
}
else {
dp[i] = dp[i-1];
}
}
cout<<dp[n]<<endl;
delete []arr;
delete []dp;
}
return 0;
}
可是看到大神优化空间后的短码,我觉得差距好大
#include<cstdio>
int main()
{
int n,test,ans,t,a,i;
scanf("%d",&test);
while(test--)
{
scanf("%d",&n);
scanf("%d",&a);
ans=t=a;
for(i=1;i<n;i++)
{
scanf("%d",&a);
if(t<0) t=a;
else t=t+a;
if(ans<t) ans=t;
}
printf("%d\n",ans);
}
return 0;
}