[dp] 蓝桥杯 地宫取宝

题意:

中文题而且很短就不说了~

思路:

四维dp[i][j][l][o] 代表在(i,j)这个位置,拿了o个宝贝,所有宝贝最大值是l的方案数。

因为宝贝的价值是0~12 我们的初始状态要是0,所以输入的时候把每个宝贝的价值加1.

然后对于每个点,都会有一个不拿的状态,和一个可能拿的状态。

直接转换下去就OK了。

代码:

#include"stdio.h"
#include"algorithm"
#include"string.h"
#include"map"
#include"iostream"
#include"queue"
#include"string"
#define mod 1000000007
using namespace std;
int dp[55][55][14][14],mp[55][55];
int main()
{
    int n,m,k;
    while(scanf("%d%d%d",&n,&m,&k)!=-1)
    {
        for(int i=0; i<n; i++)
        {
            for(int j=0; j<m; j++)
            {
                scanf("%d",&mp[i][j]);
                mp[i][j]++;
            }
        }
        memset(dp,0,sizeof(dp));
        dp[0][0][mp[0][0]][1]=1;
        dp[0][0][0][0]=1;
        for(int i=0; i<n; i++)
        {
            for(int j=0; j<m; j++)
            {
                for(int l=0; l<=13; l++)
                {
                    for(int o=0; o<=k; o++)
                    {
                        if(dp[i][j][l][o]==0) continue;
                        if(mp[i][j+1]>l)
                        {
                            dp[i][j+1][mp[i][j+1]][o+1]+=dp[i][j][l][o];
                            dp[i][j+1][mp[i][j+1]][o+1]%=mod;
                        }
                        if(mp[i+1][j]>l)
                        {
                            dp[i+1][j][mp[i+1][j]][o+1]+=dp[i][j][l][o];
                            dp[i+1][j][mp[i+1][j]][o+1]%=mod;
                        }
                        dp[i][j+1][l][o]+=dp[i][j][l][o];
                        dp[i][j+1][l][o]%=mod;
                        dp[i+1][j][l][o]+=dp[i][j][l][o];
                        dp[i+1][j][l][o]%=mod;
                    }
                }
            }
        }
        int ans=0;
        for(int i=0; i<=13; i++)
        {
            ans=(ans+dp[n-1][m-1][i][k])%mod;
        }
        printf("%d\n",ans);
    }
    return 0;
}
时间: 2024-10-13 04:16:28

[dp] 蓝桥杯 地宫取宝的相关文章

蓝桥杯 地宫取宝(12&#39;)

X 国王有一个地宫宝库.是n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大, 小明就可以拿起它(当然,也可以不拿). 当小明走到出口时,如果他手中的宝贝恰好是k件,则这些宝贝就可以送给小明. 请你帮小明算一算,在给定的局面下,他有多少种不同的行动方案能获得这k件宝贝. [数据格式] 输入一行 3个整数,用空格分开:n m

2014蓝桥杯——地宫取宝

标题:地宫取宝 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大,小明就可以拿起它(当然,也可以不拿). 当小明走到出口时,如果他手中的宝贝恰好是k件,则这些宝贝就可以送给小明. 请你帮小明算一算,在给定的局面下,他有多少种不同的行动方案能获得这k件宝贝. [数据格式] 输入一行3个整数,用空

蓝桥杯 地宫取宝

dp[x][y][num][mx]:从位置x,y,有num个物品,最大值为mx的状态,开始走到满足条件的终点,有多少种方法 http://lx.lanqiao.org/problem.page?gpid=T120 历届试题 地宫取宝 时间限制:1.0s   内存限制:256.0MB 问题描述 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如

蓝桥杯历届试题 地宫取宝 dp or 记忆化搜索

问题描述 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大,小明就可以拿起它(当然,也可以不拿). 当小明走到出口时,如果他手中的宝贝恰好是k件,则这些宝贝就可以送给小明. 请你帮小明算一算,在给定的局面下,他有多少种不同的行动方案能获得这k件宝贝. 输入格式 输入一行3个整数,用空格分开:n

蓝桥杯:地宫取宝

*/--> pre.src {background-color: Black; color: White;} 蓝桥杯:地宫取宝 Table of Contents 错误的写法 改进后 再次改进 用记忆的方法去改进 标题:地宫取宝 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大,小明就可以拿起

蓝桥杯 历届试题 地宫取宝 【记忆化搜索】

历届试题 地宫取宝 时间限制:1.0s   内存限制:256.0MB 问题描述 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大,小明就可以拿起它(当然,也可以不拿). 当小明走到出口时,如果他手中的宝贝恰好是k件,则这些宝贝就可以送给小明. 请你帮小明算一算,在给定的局面下,他有多少种不同的

蓝桥杯 2014本科C++ B组 地宫取宝 DFS+记忆化搜索

历届试题 地宫取宝   时间限制:1.0s   内存限制:256.0MB 问题描述 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大,小明就可以拿起它(当然,也可以不拿). 当小明走到出口时,如果他手中的宝贝恰好是k件,则这些宝贝就可以送给小明. 请你帮小明算一算,在给定的局面下,他有多少种不

地宫取宝 蓝桥杯 记忆化搜索 DFS

标题:地宫取宝 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大,小明就可以拿起它(当然,也可以不拿). 当小明走到出口时,如果他手中的宝贝恰好是k件,则这些宝贝就可以送给小明. 请你帮小明算一算,在给定的局面下,他有多少种不同的行动方案能获得这k件宝贝. [数据格式] 输入一行3个整数,用空

地宫取宝----第五届蓝桥杯

/* * 标题:地宫取宝 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每一个格子放一件宝贝.每一个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他仅仅能向右或向下行走. 走过某个格子时,假设那个格子中的宝贝价值比小明手中随意宝贝价值都大,小明就能够拿起它(当然,也能够不拿). 当小明走到出口时,假设他手中的宝贝恰好是k件,则这些宝贝就能够送给小明. 请你帮小明算一算,在给定的局面下.他有多少种不同的行动方案能获得这k件宝贝. [数据格式] 输入一