蓝桥杯 地宫寻宝 java_蓝桥杯 地宫寻宝 带缓存的DFS
历届试题 地宫取宝
时间限制: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相关推荐
- 地宫寻宝java_蓝桥杯 2014年 第五届 迷宫寻宝 详解(JAVA)
蓝桥杯 2014年 第五届 迷宫寻宝 详解(JAVA) 基础思路(DFS) package provincial_2014B; import java.util.Scanner; /** * 该题有两 ...
- 蓝桥杯四平方和Java_蓝桥杯 四平方和
题目:四平方和 看到这个题目,第一个思路就是: 枚举abcd的值,然后判断它们的平方和是不是等于N. 我们可以分析一下abcd的枚举范围: a : 0 ~ sqrt( 5000000 / 4 ) b ...
- 2018蓝桥杯省赛java_蓝桥杯2018年A组省赛
1.分数 1/1 + 1/2 + 1/4 + 1/8 + 1/16 + - 每项是前一项的一半,如果一共有20项, 求这个和是多少,结果用分数表示出来. 类似: 3/2 当然,这只是加了前2项而已.分 ...
- 蓝桥杯小朋友排队java_[蓝桥杯][历届试题]小朋友排队 (C++代码)
#include #define maxn 100010 struct data { int num,cnt; }A[maxn],temp[maxn]; int n; //long long ans; ...
- 蓝桥杯切面条java_[蓝桥杯][历届试题]切面条-题解(C++代码)
题目: 一根高筋拉面,中间切一刀,可以得到2根面条. 如果先对折1次,中间切一刀,可以得到3根面条. 如果连续对折2次,中间切一刀,可以得到5根面条. 那么,连续对折10次,中间切一刀,会得到多少面条 ...
- 大学生蓝桥杯比赛时间2020_2020蓝桥杯STEAM比赛考试说明
近期蓝桥杯组织了很多场的比赛,下半年基本上每个月都有,让许多家长不知所措.接下来爱思创小程老师就来跟家长们聊一下今年蓝桥杯的参赛攻略. 下半年蓝桥杯比赛,分为三个阶段:steam考试,蓝桥杯省赛,蓝桥 ...
- 蓝桥杯嵌入式——第十一届蓝桥杯嵌入式国赛
蓝桥杯嵌入式--第十一届蓝桥杯嵌入式国赛 之前准备省赛的时候用的是旧版的STM32F103,从准备国赛开始就用新版STM32G431平台了,主要是想经过新版的准备学习一下HAL库以及CubeMX的使用 ...
- 【蓝桥真题3】蓝桥改革变难,想进国赛这些能力你可缺一不可
⭐️引言⭐️ 大家好,我是执梗.蓝桥杯省赛的倒计时也就剩下一个月的时间了,如果练过近七八年的真题的小伙伴,很明显地能感觉到蓝桥杯的难度越来越大,虽然遥遥还比不上ACM,但它的平均难度正以明显地速度增加 ...
- 消愁,一杯敬故乡,一杯敬远方
消愁,一杯敬故乡,一杯敬远方 每个人的人生都是一本原生空白纸,价值观和自我意识决定了书的走向. 在那个文华尚好心性淳朴的年纪里,我也用笨拙的"文学语句"写了些诗句.文章,大多都是一 ...
最新文章
- stm32怎么用keil软件进行仿真?(必需掌握的技能)
- Windows远程桌面连接并传输文件
- awk 分隔符_awk 中的字段、记录和变量 | Linux 中国
- 透过微信应用号,看HTML5与Native进入融合时代
- WEBMIN管理Centos5.2 or RedHat5.2以上版本时samba用户不能同步系统帐户
- pipe 半双工_pipe 半双工_Linux管道PIPE的原理和应用
- 如何用c语言实现贪吃蛇登录界面,c语言贪吃蛇UI界面版.docx
- JavaScript或jQuery中使用键盘控制对象运动
- javascript中的后退和刷新
- 升讯威微信营销系统开发教程:(1)订阅号和服务号深入分析
- cos,sina,tan,cot
- BUUCTF--[GUET-CTF2019]number_game
- 谣言检测论文精读——1.IJCAI2016-Detecting Rumors from Microblogs with Recurrent Neural Networks
- POI导出word单元格合并
- 计算机基本应用能力,计算机应用能力基本.ppt
- php 禁止抓取,服务器反爬虫攻略:Apache/Nginx/PHP禁止某些User Agent抓取网站
- 微信和平精英服务器怎么填,和平精英微信游戏名片怎么设置?微信游戏名片设置方法一览[多图]...
- HTML5菜鸟入门指导:简介、平台搭建、示例演示
- 游戏老虎吃绵羊 -- lua
- 在虚拟机中通过U盘GHOST 操作系统
热门文章
- WPS for Linux 界面改为中文
- 微信小程序蓝牙通讯蓝牙模块demo
- 第六课 背景与渐变
- python序列求和
- c语言半壁江山回调函数,2021福建事业单位考试综合应用能力试题(C类):拿下“综合C”半壁江山...
- 《ICNet for Real-Time Semantic Segmentation on High-Resolution Images》论文笔记
- Linux中I2C子系统框架
- PHP网站分类目录管理系统源码优客365导航源码
- 快速导入浏览器的接口参数到postman中
- java 递归获取树的父节点_Java 树父节点递归获取树子节点