zoukankan      html  css  js  c++  java
  • codevs1068乌龟棋

    codevs1068乌龟棋

    1068 乌龟棋

     

    2010年NOIP全国联赛提高组

     时间限制: 1 s
     空间限制: 128000 KB
     题目等级 : 钻石 Diamon
     
    题目描述 Description

    小明过生日的时候,爸爸送给他一副乌龟棋当作礼物。 乌龟棋的棋盘是一行N个格子,每个格子上一个分数(非负整数)。棋盘第1格是唯一 的起点,第N格是终点,游戏要求玩家控制一个乌龟棋子从起点出发走到终点。

    …… 1 2 3 4 5 ……N 乌龟棋中M张爬行卡片,分成4种不同的类型(M张卡片中不一定包含所有4种类型 的卡片,见样例),每种类型的卡片上分别标有1、2、3、4四个数字之一,表示使用这种卡 片后,乌龟棋子将向前爬行相应的格子数。游戏中,玩家每次需要从所有的爬行卡片中选择 一张之前没有使用过的爬行卡片,控制乌龟棋子前进相应的格子数,每张卡片只能使用一次。 游戏中,乌龟棋子自动获得起点格子的分数,并且在后续的爬行中每到达一个格子,就得到 该格子相应的分数。玩家最终游戏得分就是乌龟棋子从起点到终点过程中到过的所有格子的 分数总和。 很明显,用不同的爬行卡片使用顺序会使得最终游戏的得分不同,小明想要找到一种卡 片使用顺序使得最终游戏得分最多。 现在,告诉你棋盘上每个格子的分数和所有的爬行卡片,你能告诉小明,他最多能得到 多少分吗?

    输入描述 Input Description

    输入的每行中两个数之间用一个空格隔开。 第1行2个正整数N和M,分别表示棋盘格子数和爬行卡片数。 第2行N个非负整数,a1a2……aN

    ,其中ai表示棋盘第i个格子上的分数。 第3行M个整数,b1b2……bM

    ,表示M张爬行卡片上的数字。 输入数据保证到达终点时刚好用光M张爬行卡片,即N - 1=∑(1->M) bi

    输出描述 Output Description

    输出一行一个整数

    样例输入 Sample Input

    13 8

    4 96 10 64 55 13 94 53 5 24 89 8 30

    1 1 1 1 1 2 4 1

    样例输出 Sample Output

    455

    数据范围及提示 Data Size & Hint

    【数据范围】

    对于30%的数据有1 ≤ N≤ 30,1 ≤M≤ 12。

    对于50%的数据有1 ≤ N≤ 120,1 ≤M≤ 50,且4 种爬行卡片,每种卡片的张数不会超

    过20。

    对于100%的数据有1 ≤ N≤ 350,1 ≤M≤ 120,且4 种爬行卡片,每种卡片的张数不会

    超过40;0 ≤ ai ≤ 100,1 ≤ i ≤ N;1 ≤ bi ≤ 4,1 ≤ i ≤M。输入数据保证N−1=ΣM

    【题目大意】

    一行棋盘,每个格子都有分值。一些卡片,数字为1--4,表示用这种卡片走相应的格子数。

    求得分最大。

    【思路】dp额...第一次用4维。

    dp[i][j][k][l]表示用i张1种牌,j张2种牌,K张3种牌,l张4种牌。

    转移方程为 

    dp[i][j][k][l]=max{dp[i-1][j][k][l],dp[i][j-1][k][l],dp[i][j][k-1][l],dp[i][j][k][l-1]}+qp[1+i+2*j+3*k+4*l];

    【code】

    (1)爆搜

    void dfs(int x,int a,int b,int c,int d,int get)
    {
        if(x==n){
            ans=max(ans,get);
            return ;
        }
        if(a)dfs(x+1,a-1,b,c,d,get+scor[x+1]);
        if(b)dfs(x+2,a,b-1,c,d,get+scor[x+2]);
        if(c)
        if(d)
    }

    (2)dp

    #include<iostream>
    #include<cstdio>
    using namespace std;
    int n,m,x,maxx,s[5],qp[355],f[40][40][40][40];
    int main()
    {
        scanf("%d%d",&n,&m);
        for(int i=1;i<=n;i++)
        scanf("%d",&qp[i]);
        for(int i=1;i<=m;i++)
        {
            scanf("%d",&x);
            if(x==1)s[1]++;
            if(x==2)s[2]++;
            if(x==3)s[3]++;
            if(x==4)s[4]++;
        }
        f[0][0][0][0]=qp[1];
        f[1][0][0][0]=qp[2];
        f[0][1][0][0]=qp[3];
        f[0][0][1][0]=qp[4];
        f[0][0][0][1]=qp[5];
        for(int i=0;i<=s[1];i++)
        for(int j=0;j<=s[2];j++)
        for(int l=0;l<=s[3];l++)
        for(int k=0;k<=s[4];k++)
        {
            maxx=0;
            if(i)maxx=max(maxx,f[i-1][j][l][k]);
            if(j)maxx=max(maxx,f[i][j-1][l][k]);
            if(l)maxx=max(maxx,f[i][j][l-1][k]);
            if(k)maxx=max(maxx,f[i][j][l][k-1]);
            f[i][j][l][k]=maxx+qp[i+j*2+l*3+k*4+1];
         } 
         printf("%d
    ",f[s[1]][s[2]][s[3]][s[4]]);
        return 0;
    }
  • 相关阅读:
    spring boot activiti 整合
    接管SpringBoot对Activiti的数据源自动配置
    springboot集成activiti6.0多数据源的配置
    activiti 如何使用database前缀来区分activiti数据库和业务数据库
    SpringBoot开发案例之整合Activiti工作流引擎
    Activiti6简明教程
    springboot activiti 配置项详解
    Activiti搭建
    spring boot 2.0 报错:“jdbcUrl is required with driverClassName.” 解决办法!
    TCP的可靠传输机制(简单好理解:分段与流,滑窗,连接,流量控制,重新发送,堵塞控制)
  • 原文地址:https://www.cnblogs.com/zzyh/p/7066978.html
Copyright © 2011-2022 走看看