随笔-68  评论-10  文章-0  trackbacks-0

做该题的时候,看了网上另外一个版本的递推关系,不过还是朴素一点的比较好理解.状态转移方程为:
f[i,j]=max{f[i-1,j-1],f[i-1,j],f[i-1,j+1]}+w(i,j), 其中f[i,j]表示第i 秒 ,门开放度为j 时的最大加分.w(i,j)表示在该状态下的所有加分.为防止超内存用滚动数组.(由于不仔细把1写成了i,调试了半天,杯具了~~)  详细见代码:

#include<iostream>
#include
<algorithm>
using namespace std;

int f[2][102];
int hash[30002];
int N,K,T,ans;

typedef 
struct 
{
    
int t,p,s;
}Gant;
Gant s[
102];

int cmp(Gant a,Gant b)
{
   
if(a.t<b.t) return 1;
   
else if(a.t==b.t)
   {
       
if(a.s<b.s) return 1;
   }
   
return 0;
}

int main()
{
    
int i,j,k;
    scanf(
"%d%d%d",&N,&K,&T);
    
for(i=1;i<=N;i++) scanf("%d",&s[i].t);
    
for(i=1;i<=N;i++) scanf("%d",&s[i].p);
    
for(i=1;i<=N;i++) scanf("%d",&s[i].s);

    memset(hash,
0,sizeof(hash));
    memset(f,
-1,sizeof(f));

    
for(i=1;i<=N;i++) hash[s[i].t]=1;
    sort(s
+1,s+N+1,cmp);
    f[
0][0]=0;
    ans
=0;

    
for(i=1;i<=T;i++)
        
for(j=0;j<=K;j++)
        {
            
int w=0;
            
if(hash[i])
            {
                
for(k=1;k<=N;k++)
                    
if(s[k].t==i&&s[k].s==j)
                        w
+=s[k].p;
            }
            
if(j>=1&&f[(i-1)&1][j-1]!=-1&&f[i&1][j]<f[(i-1)&1][j-1]+w)
                f[i
&1][j]=f[(i-1)&1][j-1]+w;

            
if(j+1<=K&&f[(i-1)&1][j+1]!=-1&&f[i&1][j]<f[(i-1)&1][j+1]+w)
                f[i
&1][j]=f[(i-1)&1][j+1]+w;

            
if(f[(i-1)&1][j]!=-1&&f[i&1][j]<f[(i-1)&1][j]+w)
                f[i
&1][j]=f[(i-1)&1][j]+w;

            
if(ans<f[i&1][j]) ans=f[i&1][j];
        }
    printf(
"%d\n",ans);
    
return 0;
}
posted on 2010-08-09 17:43 wuxu 阅读(137) 评论(0)  编辑 收藏 引用 所属分类: 动态规划

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