hdu1087: Super Jumping! Jumping! Jumping!

hdu1087: http://acm.hdu.edu.cn/showproblem.php?pid=1087
题意:跳格,每个格有一个分数值,只能从分数值低的跳到分数值高的,求最大值
解法:dp:dp[i]表示直到第i个格子的最优值,则转移方程为:dp[i]=max(dp[i],dp[j]+v[i])(0<j<i)
code:
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int v[1001],dp[1001];
int max(int a,int b)
{
    if(a>b)
        return a;
    else
        return b;
}
int main()
{
    int n,i,t,j,l,ma;
    while(1)
    {
        scanf("%d",&n);
        if(n==0)break;
        for(i=0;i<n;i++)
            scanf("%d",&v[i]);
        memset(dp,0,sizeof(dp));
        dp[0]=v[0];
        for(i=1;i<n;i++)
        {
            l=0;           //l标记是否有更新过
            for(j=i-1;j>=0;j--)
            {
                if(v[i]>v[j])
                {
                    dp[i]=max(dp[i],dp[j]+v[i]);l=1;
                }
            }
            if(l==0)           //若i前面所有数都比i大,则比较dp[i]和当前值v[i]的大小
                dp[i]=max(v[i],dp[i]);
        }
        ma=dp[0];
        for(i=0;i<n;i++)
            if(dp[i]>ma)
                ma=dp[i];
        printf("%d\n",ma);
    }
}
/*input:
3 1 3 2
4 1 2 3 4
4 3 3 2 1
8 7 8 2 3 4 5 6 8
0
output:
4
10
3
28*/

posted on 2012-07-25 14:46  acmer-jun  阅读(124)  评论(0编辑  收藏  举报

导航