历届试题 地宫取宝

时间限制:1.0s   内存限制:256.0MB

问题描写叙述

X 国王有一个地宫宝库。

是 n x m 个格子的矩阵。

每一个格子放一件宝贝。

每一个宝贝贴着价值标签。

地宫的入口在左上角,出口在右下角。

小明被带到地宫的入口,国王要求他仅仅能向右或向下行走。

走过某个格子时,假设那个格子中的宝贝价值比小明手中随意宝贝价值都大,小明就能够拿起它(当然,也能够不拿)。

当小明走到出口时,假设他手中的宝贝恰好是k件,则这些宝贝就能够送给小明。

请你帮小明算一算,在给定的局面下,他有多少种不同的行动方案能获得这k件宝贝。

输入格式

输入一行3个整数,用空格分开:n m k (1<=n,m<=50, 1<=k<=12)

接下来有 n 行数据,每行有 m 个整数 Ci (0<=Ci<=12)代表这个格子上的宝物的价值

输出格式

要求输出一个整数,表示正好取k个宝贝的行动方案数。该数字可能非常大。输出它对 1000000007 取模的结果。

例子输入

2 2 2

1 2

2 1

例子输出

2

例子输入

2 3 2

1 2 3

2 1 5

例子输出

dp[x][y][num][maxValue]  代表走到(x,y)位置的时候手里持有num个宝贝并且最大值为maxValue的方案数.

该数组一開始初始化为-1.

#include

#include

#include

#include

using namespace std;

#define eps 10e-10

#define N 1000000007

int ans;

int d[51][51][13][14];

int p[51][51];

int n,m,k;

int dfs(int x,int y,int num,int maxvalue){

if(d[x][y][num][maxvalue+1] != -1){//表示这个状态已经訪问过了,方案数已经确定了.

return d[x][y][num][maxvalue+1];

}

int t = 0;

if(x == n-1 && y == m-1){

if(num==k||(num==k-1&&p[x][y]>maxvalue))

return d[x][y][num][maxvalue+1] = 1;

else

return d[x][y][num][maxvalue+1] = 0;

}

if(x + 1 < n){

if(p[x][y] > maxvalue){

t += dfs(x+1,y,num+1,p[x][y]);

t %= N;

}

t += dfs(x+1,y,num,maxvalue);

t %= N;

}

if(y + 1 < m){

if(p[x][y] > maxvalue){

t += dfs(x,y+1,num+1,p[x][y]);

t %= N;

}

t += dfs(x,y+1,num,maxvalue);

t %= N;

}

d[x][y][num][maxvalue+1] = t;

return d[x][y][num][maxvalue+1];

}

int main(){

while(cin>>n>>m>>k){

for(int i = 0; i < n; ++i){

for(int j = 0; j < m; ++j)

cin>>p[i][j];

}

memset(d,-1,sizeof(d));

d[0][0][0][0] = dfs(0,0,0,-1);//由于宝贝的最小价值能够为0

cout<

}

return 0;

}

蓝桥杯 地宫寻宝 java_蓝桥杯 地宫寻宝 带缓存的DFS相关推荐

  1. 地宫寻宝java_蓝桥杯 2014年 第五届 迷宫寻宝 详解(JAVA)

    蓝桥杯 2014年 第五届 迷宫寻宝 详解(JAVA) 基础思路(DFS) package provincial_2014B; import java.util.Scanner; /** * 该题有两 ...

  2. 蓝桥杯四平方和Java_蓝桥杯 四平方和

    题目:四平方和 看到这个题目,第一个思路就是: 枚举abcd的值,然后判断它们的平方和是不是等于N. 我们可以分析一下abcd的枚举范围: a : 0 ~ sqrt( 5000000 / 4 ) b  ...

  3. 2018蓝桥杯省赛java_蓝桥杯2018年A组省赛

    1.分数 1/1 + 1/2 + 1/4 + 1/8 + 1/16 + - 每项是前一项的一半,如果一共有20项, 求这个和是多少,结果用分数表示出来. 类似: 3/2 当然,这只是加了前2项而已.分 ...

  4. 蓝桥杯小朋友排队java_[蓝桥杯][历届试题]小朋友排队 (C++代码)

    #include #define maxn 100010 struct data { int num,cnt; }A[maxn],temp[maxn]; int n; //long long ans; ...

  5. 蓝桥杯切面条java_[蓝桥杯][历届试题]切面条-题解(C++代码)

    题目: 一根高筋拉面,中间切一刀,可以得到2根面条. 如果先对折1次,中间切一刀,可以得到3根面条. 如果连续对折2次,中间切一刀,可以得到5根面条. 那么,连续对折10次,中间切一刀,会得到多少面条 ...

  6. 大学生蓝桥杯比赛时间2020_2020蓝桥杯STEAM比赛考试说明

    近期蓝桥杯组织了很多场的比赛,下半年基本上每个月都有,让许多家长不知所措.接下来爱思创小程老师就来跟家长们聊一下今年蓝桥杯的参赛攻略. 下半年蓝桥杯比赛,分为三个阶段:steam考试,蓝桥杯省赛,蓝桥 ...

  7. 蓝桥杯嵌入式——第十一届蓝桥杯嵌入式国赛

    蓝桥杯嵌入式--第十一届蓝桥杯嵌入式国赛 之前准备省赛的时候用的是旧版的STM32F103,从准备国赛开始就用新版STM32G431平台了,主要是想经过新版的准备学习一下HAL库以及CubeMX的使用 ...

  8. 【蓝桥真题3】蓝桥改革变难,想进国赛这些能力你可缺一不可

    ⭐️引言⭐️ 大家好,我是执梗.蓝桥杯省赛的倒计时也就剩下一个月的时间了,如果练过近七八年的真题的小伙伴,很明显地能感觉到蓝桥杯的难度越来越大,虽然遥遥还比不上ACM,但它的平均难度正以明显地速度增加 ...

  9. 消愁,一杯敬故乡,一杯敬远方

    消愁,一杯敬故乡,一杯敬远方 每个人的人生都是一本原生空白纸,价值观和自我意识决定了书的走向. 在那个文华尚好心性淳朴的年纪里,我也用笨拙的"文学语句"写了些诗句.文章,大多都是一 ...

最新文章

  1. stm32怎么用keil软件进行仿真?(必需掌握的技能)
  2. Windows远程桌面连接并传输文件
  3. awk 分隔符_awk 中的字段、记录和变量 | Linux 中国
  4. 透过微信应用号,看HTML5与Native进入融合时代
  5. WEBMIN管理Centos5.2 or RedHat5.2以上版本时samba用户不能同步系统帐户
  6. pipe 半双工_pipe 半双工_Linux管道PIPE的原理和应用
  7. 如何用c语言实现贪吃蛇登录界面,c语言贪吃蛇UI界面版.docx
  8. JavaScript或jQuery中使用键盘控制对象运动
  9. javascript中的后退和刷新
  10. 升讯威微信营销系统开发教程:(1)订阅号和服务号深入分析
  11. cos,sina,tan,cot
  12. BUUCTF--[GUET-CTF2019]number_game
  13. 谣言检测论文精读——1.IJCAI2016-Detecting Rumors from Microblogs with Recurrent Neural Networks
  14. POI导出word单元格合并
  15. 计算机基本应用能力,计算机应用能力基本.ppt
  16. php 禁止抓取,服务器反爬虫攻略:Apache/Nginx/PHP禁止某些User Agent抓取网站
  17. 微信和平精英服务器怎么填,和平精英微信游戏名片怎么设置?微信游戏名片设置方法一览[多图]...
  18. HTML5菜鸟入门指导:简介、平台搭建、示例演示
  19. 游戏老虎吃绵羊 -- lua
  20. 在虚拟机中通过U盘GHOST 操作系统

热门文章

  1. WPS for Linux 界面改为中文
  2. 微信小程序蓝牙通讯蓝牙模块demo
  3. 第六课 背景与渐变
  4. python序列求和
  5. c语言半壁江山回调函数,2021福建事业单位考试综合应用能力试题(C类):拿下“综合C”半壁江山...
  6. 《ICNet for Real-Time Semantic Segmentation on High-Resolution Images》论文笔记
  7. Linux中I2C子系统框架
  8. PHP网站分类目录管理系统源码优客365导航源码
  9. 快速导入浏览器的接口参数到postman中
  10. java 递归获取树的父节点_Java 树父节点递归获取树子节点