zoukankan      html  css  js  c++  java
  • P1541

    P1541

    题目背景

    小明过生日的时候,爸爸送给他一副乌龟棋当作礼物。

    题目描述

    乌龟棋的棋盘是一行N个格子,每个格子上一个分数(非负整数)。棋盘第1格是唯一的起点,第N格是终点,游戏要求玩家控制一个乌龟棋子从起点出发走到终点。

    乌龟棋中M张爬行卡片,分成4种不同的类型(M张卡片中不一定包含所有4种类型的卡片,见样例),每种类型的卡片上分别标有1,2,3,4四个数字之一,表示使用这种卡片后,乌龟棋子将向前爬行相应的格子数。游戏中,玩家每次需要从所有的爬行卡片中选择一张之前没有使用过的爬行卡片,控制乌龟棋子前进相应的格子数,每张卡片只能使用一次。

    游戏中,乌龟棋子自动获得起点格子的分数,并且在后续的爬行中每到达一个格子,就得到该格子相应的分数。玩家最终游戏得分就是乌龟棋子从起点到终点过程中到过的所有格子的分数总和。

    很明显,用不同的爬行卡片使用顺序会使得最终游戏的得分不同,小明想要找到一种卡片使用顺序使得最终游戏得分最多。

    现在,告诉你棋盘上每个格子的分数和所有的爬行卡片,你能告诉小明,他最多能得到多少分吗?

    输入格式

    每行中两个数之间用一个空格隔开。

    12个正整数N,M,分别表示棋盘格子数和爬行卡片数。

    2行N个非负整数,a1,a2,,aN,其中ai表示棋盘第i个格子上的分数。

    3M个整数,b1,b2,,bM,表示M张爬行卡片上的数字。

    输入数据保证到达终点时刚好用光M张爬行卡片。

    输出格式

    1个整数,表示小明最多能得到的分数。

    输入输出样例

    输入 #1
    9 5
    6 10 14 2 8 8 18 5 17
    1 3 1 2 1
    
    输出 #1
    73
    

    说明/提示

    每个测试点1s

    小明使用爬行卡片顺序为1,1,3,1,2得到的分数为6+10+14+8+18+17=73。注意,由于起点是1,所以自动获得第1格的分数6。

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

    对于50%的数据有1N120,1M50,且4种爬行卡片,每种卡片的张数不会超过20。

    对于100%的数据有1N350,1M120,且4种爬行卡片,每种卡片的张数不会超过40;0ai100,1iN,1bi4,1iM。

    还是四维dp..

     1 #include<iostream>
     2 #include<algorithm>
     3 #include<cstdio>
     4 #include<cstdlib> 
     5 using namespace std;
     6 int f[45][45][45][45],v[500];
     7 int n,m;
     8 int a,b,c,d;
     9 int cnt;
    10 int main() {
    11   cin>>n>>m;
    12   for(int i=1;i<=n;i++){
    13     cin>>v[i];
    14   }
    15   for(int i=1;i<=m;i++){
    16     int x;
    17     scanf("%d",&x);
    18     if(x==1){a++;}
    19     if(x==2){b++;}
    20     if(x==3){c++;}
    21     if(x==4){d++;}
    22   }  
    23   f[1][1][1][1]=v[1]; 
    24   for(int i=1;i<=a+1;i++){
    25     for(int j=1;j<=b+1;j++){
    26         for(int k=1;k<=c+1;k++){
    27             for(int l=1;l<=d+1;l++){
    28                 cnt=i+j*2+k*3+l*4-9; //边界
    29                 f[i][j][k][l]=max(f[i][j][k][l],f[i-1][j][k][l]+v[cnt]);
    30                 f[i][j][k][l]=max(f[i][j][k][l],f[i][j-1][k][l]+v[cnt]);
    31                 f[i][j][k][l]=max(f[i][j][k][l],f[i][j][k-1][l]+v[cnt]);
    32                 f[i][j][k][l]=max(f[i][j][k][l],f[i][j][k][l-1]+v[cnt]);
    33             }
    34         }
    35     }
    36   }
    37   cout<<f[a+1][b+1][c+1][d+1]<<endl;
    38   return 0;
    39 }
  • 相关阅读:
    powerbulider9.0在数据窗口中实现滚动到新添加行
    C#获取当前路径,获取当前路径的上一层路径
    java开发工具使用
    plsql高级查询命令
    oracle基础命令
    oracle-11g-64位安装和plaql
    初识设计模式(装饰者模式)
    初识设计模式(观察者模式)
    观察者模式与发布订阅者模式的区别
    初识设计模式(策略模式)
  • 原文地址:https://www.cnblogs.com/Gzznnn/p/13836107.html
Copyright © 2011-2022 走看看