首页 > 其他分享 >乌龟棋

乌龟棋

时间:2022-08-26 15:03:05浏览次数:79  
标签:分数 cn int MAX 乌龟 define

P1541 [NOIP2010 提高组] 乌龟棋 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

  • 四维dp
  • 从前往后枚举所有可能的状态,对于所有枚举到的状态用当前这步棋不走的分数再加上这个位置的分数的和来更新,比如如果有走a个1步棋,a-1步的分数一定知道,再加上走上这一步将获得的分数来更新状态。
https://www.luogu.com.cn/problem/P1541
#include <bits/stdc++.h>
using namespace std;
#define N 1e5
#define INF 2e9
#define MAX 50

int n, m;
int dp[MAX][MAX][MAX][MAX], value[MAX * 100], nums[5];
int main()
{
    cin >> n >> m;
    for (int i = 1; i <= n; i++)
        scanf("%d", value + i);
    for (int i = 1, t; i <= m; i++)
    {
        scanf("%d", &t);
        nums[t]++;
    }
    dp[0][0][0][0] = value[1];
    for (int a = 0; a <= nums[1]; a++)
        for (int b = 0; b <= nums[2]; b++)
            for (int c = 0; c <= nums[3]; c++)
                for (int d = 0; d <= nums[4]; d++)
                {
                    int pos = 1 + a + b * 2 + c * 3 + d * 4;
                    if (a)
                        dp[a][b][c][d] = max(dp[a - 1][b][c][d] + value[pos], dp[a][b][c][d]);
                    if (b)
                        dp[a][b][c][d] = max(dp[a][b - 1][c][d] + value[pos], dp[a][b][c][d]);
                    if (c)
                        dp[a][b][c][d] = max(dp[a][b][c - 1][d] + value[pos], dp[a][b][c][d]);
                    if (d)
                        dp[a][b][c][d] = max(dp[a][b][c][d - 1] + value[pos], dp[a][b][c][d]);
                }
    printf("%d", dp[nums[1]][nums[2]][nums[3]][nums[4]]);
}

 

标签:分数,cn,int,MAX,乌龟,define
From: https://www.cnblogs.com/Wang-Xianyi/p/16627548.html

相关文章