单链DNA

换了个地址:http://www.cnblogs.com/vizhen/

 

HDOJ 1003 MaxSum--最大子序列和


题目:http://acm.hdu.edu.cn/showproblem.php?pid=1003

算法思想:
       设S[j]为以a[j]结尾的子序列最大的和,那么,
             S[1]=a[1];
             S[j]=S[j-1]>=0?S[j-1]+a[j]:a[j];
       那么要求的连续子序列中有最大和的就是S[1],S[2],......,S[n]中最大的。

算法设计:
      
 1 int a[100001];
 2 int s[100001];
 3 int n,str,end;
 4 
 5 int DPMaxSum(int n)
 6 {
 7     int max;
 8     int restr;
 9     str=restr=1;
10     end=1;
11     max=s[1]=a[1];
12     
13     for(int i=2;i<=n;i++)
14     {
15        if(s[i-1]>=0)
16        {
17            s[i]=s[i-1]+a[i];
18        }
19        else
20        {
21            s[i]=a[i];
22            restr=i;
23         }
24        if(max<=s[i])
25        {
26           max=s[i];
27           str=restr;
28           end=i;
29        }
30     }
31     return max;
32 }
33 

优化:求S[i]只依赖于前一个S[i-1]和a[i],所以还可以优化算法。
     
 1 #include<stdio.h>
 2 int i,cas,j,k,t,max,s,e,n,x;
 3 main()
 4 {
 5     while(scanf("%d",&cas)!=EOF)
 6     {
 7         for(i=0;i<cas;i++)
 8         {
 9             if(i)printf("\n");
10             printf("Case %d:\n",i+1);
11             scanf("%d",&n);
12             max=-99;
13             for(j=k=1,t=0;j<=n;j++)
14             {
15                 scanf("%d",&x);
16                 t+=x;
17                 if(t>max)  {max=t;s=k;e=j;}
18                 if(t<0)      {k=j+1;t=0;}
19             }
20             printf("%d %d %d\n",max,s,e);
21         }
22     }
23 }
24 


posted on 2010-07-19 12:02 Geek.tan 阅读(1329) 评论(4)  编辑 收藏 引用 所属分类: ACM解题报告

评论

# re: HDOJ 1003 MaxSum--最大子序列和 2010-07-20 23:26 付翔

恩 ACMER 加油 !  回复  更多评论   

# re: HDOJ 1003 MaxSum--最大子序列和 2010-07-21 10:12 Geek.tan

@付翔
the same to you  回复  更多评论   

# re: HDOJ 1003 MaxSum--最大子序列和 2011-07-18 08:19 郭宝星

第一个算法对吗??我怎么wrong呢??求解新手

#include <stdio.h>


int main()
{
int i,a[100000],max,start=1,rstart=1,end=1,s[100000],p=1,t,n;
scanf("%d",&t);
while(t--)
{

scanf("%d",&n);
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
max=s[1]=a[1];
for(i=2;i<=n;i++)
{
if(s[i-1]>=0)
{
s[i]=s[i-1]+a[i];
}
else
{
s[i]=a[i];
rstart=i;
}
if(max<=s[i])
{
max=s[i];
end=i;
start=rstart;
}
}

printf("Case %d:\n",p++);
printf("%d %d %d\n",max,start,end);
if(t!=0)
printf("\n");
}
return 0;
}
  回复  更多评论   

# re: HDOJ 1003 MaxSum--最大子序列和 2011-07-18 09:25 Geek.tan

@郭宝星
好久以前做的,应该没错,你数组a[100000]和s[100000]少了吧,N可以取到100000   回复  更多评论   


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


导航

统计

公告

coding是我的寂寞,我是谁的寂寞

随笔分类(40)

随笔档案(48)

搜索

积分与排名

最新评论

评论排行榜