18.03.05 codevs1068 烏龜棋
小明過生日的時候,爸爸送給他一副烏龜棋當作禮物。 烏龜棋的棋盤是一行N個格子,每個格子上一個分數(非負整數)。棋盤第1格是唯一 的起點,第N格是終點,遊戲要求玩家控制一個烏龜棋子從起點出發走到終點。
…… 1 2 3 4 5 ……N 烏龜棋中M張爬行卡片,分成4種不同的類型(M張卡片中不一定包含所有4種類型 的卡片,見樣例),每種類型的卡片上分別標有1、2、3、4四個數字之一,表示使用這種卡 片後,烏龜棋子將向前爬行相應的格子數。遊戲中,玩家每次需要從所有的爬行卡片中選擇 一張之前沒有使用過的爬行卡片,控制烏龜棋子前進相應的格子數,每張卡片只能使用一次。 遊戲中,烏龜棋子自動獲得起點格子的分數,並且在後續的爬行中每到達一個格子,就得到 該格子相應的分數。玩家最終遊戲得分就是烏龜棋子從起點到終點過程中到過的所有格子的 分數總和。 很明顯,用不同的爬行卡片使用順序會使得最終遊戲的得分不同,小明想要找到一種卡 片使用順序使得最終遊戲得分最多。 現在,告訴你棋盤上每個格子的分數和所有的爬行卡片,你能告訴小明,他最多能得到 多少分嗎?
輸入的每行中兩個數之間用一個空格隔開。 第1行2個正整數N和M,分別表示棋盤格子數和爬行卡片數。 第2行N個非負整數,a1a2……aN
,其中ai表示棋盤第i個格子上的分數。 第3行M個整數,b1b2……bM
,表示M張爬行卡片上的數字。 輸入數據保證到達終點時剛好用光M張爬行卡片,即N - 1=∑(1->M) bi
輸出描述 Output Description輸出一行一個整數
樣例輸入 Sample Input13 8
4 96 10 64 55 13 94 53 5 24 89 8 30
1 1 1 1 1 2 4 1
樣例輸出 Sample Output455
數據範圍及提示 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
i b
1
1 #include <iostream> 2 #include <cstdio> 3 #include <memory.h> 4 #include <algorithm> 5 6 using namespace std; 7 8 int blo[400],cou[5]={0},f[42][42][42][42]={0},a,b,c,d;//blo存放格子分數 cou存放每張卡牌的數量 f存放用了四張卡片分別幾張的時候所得的最大分數 9 10 int main() 11 { 12 int n,m;//n格子數 m卡牌數 13 scanf("%d%d",&n,&m); 14 for(int i=1;i<=n;i++) 15 scanf("%d",&blo[i]); 16 for(int i=1;i<=m;i++) 17 { 18 int a; 19 scanf("%d",&a); 20 cou[a]++; 21 } 22 f[0][0][0][0]=blo[1]; 23 for(a=0;a<=cou[1];a++) 24 for(b=0;b<=cou[2];b++) 25 for(c=0;c<=cou[3];c++) 26 for(d=0;d<=cou[4];d++) 27 { 28 int max0=f[0][0][0][0],t=a+b*2+c*3+d*4+1; 29 if(a) 30 max0=max(max0,f[a-1][b][c][d]+blo[t]); 31 if(b) 32 max0=max(max0,f[a][b-1][c][d]+blo[t]); 33 if(c) 34 max0=max(max0,f[a][b][c-1][d]+blo[t]); 35 if(d) 36 max0=max(max0,f[a][b][c][d-1]+blo[t]); 37 f[a][b][c][d]=max0; 38 } 39 printf("%d",f[cou[1]][cou[2]][cou[3]][cou[4]]); 40 return 0; 41 }View Code
四維?!?!
大數組上提……
忘了……
查錯查了好久……
18.03.05 codevs1068 烏龜棋