zoukankan      html  css  js  c++  java
  • ZOJ 3741 Eternal Reality [dp]

    In Academy City, most students have special abilities. Such as Railgun, Teleport, Telekinesis, AIM Stalker and so on. Here, AIM (An Involuntary Movement) is a term used to refer to the phenomenon in which an esper involuntarily produces an invisible energy field around the esper. Different students have different type of AIM dispersion field, so they also have different level of abilities.

    Of course, a higher level students can often deal with more issues than a lower level students. To classify the students in Academy City, there are 7 levels in total:

    Level Term Description
    Level 0 Person with No Powers Most students of this level can't keep up at school. They might possess some degree of power, but unable to truly control it.
    Level 1 Person with Low Powers Powers of the degree to bend a spoon, many students belong here.
    Level 2 Person with Unusual Powers Just like Level 1, powers are not very useful in everyday life.
    Level 3 Person with Strong Powers The degree when powers are considered convenient in everyday life, ability-wise this is the Level when one starts to be treated as part of the elite.
    Level 4 Person with Great Powers Powers of an extent that their owner acquires tactical value of a military force.
    Level 5 Person with Super Powers Powers of an extent that their owner can fight alone against a military force on equal terms.
    Level 6 Person with Absolute Powers Powers of an extent that they're considered immeasurable. However, no one can achieve this level, even with the help of Level Upper (it has no effect on persons with super powers). Since this, many institutions have been doing long-term researches about it, such as the Radio Noise Project.

    You are a student of level L in Academy City and you are going to take part in a sports competition. The competition consists of N consecutive matches. If you want to get a point in the i-th match, your must reach at least Ai level. According to the rules, you must compete in all matches one by one.

    To tell the truth, it won't be easy to compete with so many high-level opponents. Fortunately, you got a special item called Level Upper. Generally, it can increase your level by 1 for a short time. If you use the Level Upper before the i-th match, it's effect will last during the matches [i, i + X - 1]. But it also has a side effect that will make your level become 0 during the matches [i + X, i + X + Y - 1]. After the side effect ends, your level will return to L and you can use the Level Upper again.

    Please calculate the maximal points you can get if you properly use the Level Upper.

    Input

    There are multiple test cases (plenty of small cases with several large cases). For each test case:

    The first line contains four integers L (0 <= L <= 5), N, X and Y (1 <= N, X, Y <= 100). The next line contains N integers Ai (0 <= Ai <= 6).

    Output

    For each test case, output the maximal points you can get.

    Sample Input

    3 6 1 2
    1 3 4 5 6 4
    

    Sample Output

    4
    

    Hint

    Read the problem description carefully.



    题意:有n个关卡,每关一个难度ai,一个等级为L的人要连续闯关,当L>=ai时他就可以得1分,否则不得分(继续下一关)。喝一次药可以使他的等级+1,持续x关,之后会出现副作用,他的等级变成0,持续y关,再过后又回复正常,可以继续喝药。问他最多得多少分。关卡难度有0~6,人的等级L为0~5。

    注意一点,就算喝药也不能到达6级!!


    d[i][j]表示前i关,最后一次在第j关喝药可以得到的最高分。


    d[i][j] = d[i-1][j] + 第i关得分(视药效情况)      , j < i

    d[i][i] = max{ d[i-1][k] } + (L+1 >= a[i])     , k <= i - x - y



    一开始判断如果L等于5那就直接统计难度小于等于5的关卡数就行。



    #include<cassert>
    #include<algorithm>
    #include<cmath>
    #include<iostream>
    #include<cstdio>
    #include<cstring>
    #include<vector>
    #include<set>
    #include<queue>
    #include<map>
    using namespace std;
    #define rep(i,f,t) for(int i = (f), _end = (t); i <= _end; ++i)
    #define clr(c,x) memset(c,x,sizeof(c));
    #define debug(x) cout<<"debug  "<<x<<endl;
    const int INF = 0x3f3f3f3f;
    typedef long long int64;
    //*******************************************************************************
    
    const int maxn = 110;
    int a[maxn];
    int d[maxn][maxn];
    
    
    int main(){
        //freopen("3741.in","r",stdin);
        int lv,n,x,y;
        while(~scanf("%d%d%d%d",&lv,&n,&x,&y)){
            rep(i,1,n) scanf("%d",a+i); 
            if(lv == 5){
                int ans = 0;
                rep(i,1,n)if(a[i] <= 5)++ans;
                printf("%d
    ",ans);
                continue;
            }
    
            d[1][0] = (lv >= a[1]);
            d[1][1] = (lv+1 >= a[1]);
            rep(i,2,n){
                d[i][0] = d[i-1][0] + (lv >= a[i]);   //d[i][0]表示从没喝药
                rep(j,1,i-1){
                    d[i][j] = d[i-1][j];
                    if(i < j+x)
                        d[i][j] += (lv+1 >= a[i]);        //有效期
                    else if(i < j+x+y)
                        d[i][j] += (0 >= a[i]);          //副作用期
                    else
                        d[i][j] += (lv >= a[i]);          //已经回复正常
                }
                d[i][i] = d[i-1][0] + (lv+1 >= a[i]);
                rep(k,1,i-x-y){
                    d[i][i] = max( d[i][i], d[i-1][k] + (lv+1 >= a[i]) );
                }
            }
    
            int ans = 0;
            rep(j,0,n){
                ans = max(ans, d[n][j]);
            }
            printf("%d
    ",ans);
        }
        return 0;
    }
    


    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    整理公共基础库子系统和系统属性组件
    鸿蒙轻内核M核源码分析系列六 任务及任务调度(1)任务栈
    HarmonyOS三方件开发指南(19)-BGABadgeView徽章组件
    鸿蒙的DFX子系统
    安卓to鸿蒙系列:ButterKnife(一)
    基于Neptune开发板的键盘蓝牙模块DIY指南
    徒手撸一个Spring Boot中的starter
    这三道最基础的java面试题,你真的答得上来吗?
    奇葩java迭代器面试题,还真有很多人踩坑
    15道类和对象面试题,快看看自己会几道
  • 原文地址:https://www.cnblogs.com/DSChan/p/4861987.html
Copyright © 2011-2022 走看看