leetcode 864. 获取所有钥匙的最短路径(BFS,状态压缩)
题目链接
题意
给定起点,要求在最短步骤内收集完所有钥匙,遇到每把锁之前只有 有对应的钥匙才能够打开
思路
BFS+状态压缩典型题目
先确定起点和总的钥匙数目,其次难点有两处:
- 如何确定当前路径下已经收集好特定的钥匙
- 如何确定钥匙已经全部收集完成
第一个问题:可以把每一个节点的状态定义为(x,y,state),其中state为钥匙数目的二进制表示,例如现在收集'b'这把钥匙,那么state更新为2(000010),括号里面为钥匙的二进制数,如果下一轮遇到'B',只需要检查state里面的倒数第二位是否已经更新即可
第二个问题:钥匙全部收集好的话,那么statey应该为(1<<cnt)-1,其中cnt为总的钥匙数量,比如有6把钥匙,全部收集满的状态为2^6-1(111111),括号里面为钥匙的二进制数
class Solution {
public:
//怎么记录更新之后的连续状态呢
//需要学习的是并非整个路径的状态 ,而是需要记录到某个节点的状态[x][y][state]
//1. 有时候可能需要走回头路? 那标记的时候除了位置,再把状态也给标记上
//2. 怎么判断钥匙已经全部取完? (1<<max_len-1) 全部标记
struct Node{
int x,y,state;
Node(int x0,int y0,int state0){
x=x0;y=y0;state=state0;
}
};
int dx[4]={1,-1,0,0};
int dy[4]={0,0,1,-1};
// unordered_set<Node> st;
int st[31][31][129];
queue<Node> Q;
int shortestPathAllKeys(vector<string>& grid) {
memset(st,0,sizeof(st));
if(grid.empty()) return 0;
int n=grid.size();
int m=grid[0].size();//n行m列
int cnt=0,nx=-1,ny=-1;//钥匙数量,初始值的位置
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
if(grid[i][j]=='@') {nx=i;ny=j;}
else if(grid[i][j]>='a' &&grid[i][j]<='z') cnt++;
}
}
Q.push(Node{nx,ny,0});
st[nx][ny][0]=1;
int step=0;//移动次数
while(!Q.empty()){
int len=Q.size();//这一层的节点数
// if(cnt<=0) break;
for(int i=0;i<len;i++){
Node cur=Q.front();
Q.pop();
if(cur.state==(1<<cnt)-1) return step;
for(int k=0;k<4;k++){
int tmpx=cur.x+dx[k];
int tmpy=cur.y+dy[k];
int nState=cur.state;
if(tmpx <0 || tmpx >n-1 || tmpy<0 || tmpy>m-1) continue;//0~n-1 这里不是n 而是大于n-1.......
if(grid[tmpx][tmpy]=='#') continue;
if(grid[tmpx][tmpy]>='a' && grid[tmpx][tmpy]<='z'){
nState=cur.state|(1<<(grid[tmpx][tmpy]-'a'));
}
if(grid[tmpx][tmpy]>='A' && grid[tmpx][tmpy]<='Z'){
// printf("%d %d\n",nState,nState & (1<<(grid[tmpx][tmpy]-'A')));
if((nState & (1<<(grid[tmpx][tmpy]-'A')))==0){
continue;
}
}
//表示已经访问过 加上状态
if(!st[tmpx][tmpy][nState]){
st[tmpx][tmpy][nState]=1;
Q.push(Node{tmpx,tmpy,nState});
}
}
}
step++;
}
return -1;
}
};
leetcode 864. 获取所有钥匙的最短路径(BFS,状态压缩)的更多相关文章
- HDU1429+bfs+状态压缩
bfs+状态压缩思路:用2进制表示每个钥匙是否已经被找到.. /* bfs+状态压缩 思路:用2进制表示每个钥匙是否已经被找到. */ #include<algorithm> #inclu ...
- BFS+状态压缩 hdu-1885-Key Task
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1885 题目意思: 给一个矩阵,给一个起点多个终点,有些点有墙不能通过,有些点的位置有门,需要拿到相应 ...
- BFS+状态压缩 HDU1429
胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- hdoj 5094 Maze 【BFS + 状态压缩】 【好多坑】
Maze Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 100000/100000 K (Java/Others) Total Sub ...
- ACM/ICPC 之 BFS+状态压缩(POJ1324(ZOJ1361))
求一条蛇到(1,1)的最短路长,题目不简单,状态较多,需要考虑状态压缩,ZOJ的数据似乎比POj弱一些 POJ1324(ZOJ1361)-Holedox Moving 题意:一条已知初始状态的蛇,求其 ...
- poj 1753 Flip Game(bfs状态压缩 或 dfs枚举)
Description Flip game squares. One side of each piece is white and the other one is black and each p ...
- HDU 3247 Resource Archiver (AC自己主动机 + BFS + 状态压缩DP)
题目链接:Resource Archiver 解析:n个正常的串.m个病毒串,问包括全部正常串(可重叠)且不包括不论什么病毒串的字符串的最小长度为多少. AC自己主动机 + bfs + 状态压缩DP ...
- [Swift]LeetCode864. 获取所有钥匙的最短路径 | Shortest Path to Get All Keys
We are given a 2-dimensional grid. "." is an empty cell, "#" is a wall, "@& ...
- HDU1429--胜利大逃亡(续)(BFS+状态压缩)
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission( ...
随机推荐
- 热部署Devtools
在子工程添加devtools的依赖 <dependency> <groupId>org.springframework.boot</groupId> <art ...
- Unity 黑暗之光 笔记 第三章
第三章 角色控制 1.创建游戏运行场景并导入素材资源 2.创建和管理标签 1 //const 表明这个是一个共有的不可变的变量 2 public const string ground = &qu ...
- Spark性能调优篇八之shuffle调优
1 task的内存缓冲调节参数 2 reduce端聚合内存占比 spark.shuffle.file.buffer map task的内存缓冲调节参数,默认是3 ...
- MySQL在Windows下压缩包方式安装与卸载
一.MySQL的卸载: 1.停止MySQL服务 2.移除MySQL 二.安装: 1.官网下载压缩版 https://downloads.mysql.com/archives/community/ 2. ...
- Powerdesigner中表导出sql语句关于字段注释乱码的问题
问题说明 注释中的汉字都变成了?,应该是编码的问题. declare @CurrentUser sysname select @CurrentUser = user_name() execute sp ...
- ubuntu20部署php-swoole开发环境
第1步:安装依赖 add-apt-repository ppa:ondrej/php apt install php-dev 第2步:编译安卓swoole wget https://codeload. ...
- 2.mysql explain命令详解
EXPLAIN详解 SQL编写和解析 编写过程 select-distinct-from-join-on-where-group by-having-order by-limit- 解析过程 from ...
- Astra示例程序库正式上线啦
新上线的Astra示例程序库提供了基于多种编程语言和框架使用Astra的例子.借助这个示例程序库,你可以在短时间内建构起数据库.创建多个表.装载示例数据并部署基于Cassandra的应用程序. 什么是 ...
- [转载]Mybatis Generator最完整配置详解
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration ...
- [LeetCode]172. Factorial Trailing Zeroes阶乘尾随0的个数
所有的0都是有2和45相乘得'到的,而在1-n中,2的个数是比5多的,所以找5的个数就行 但是不要忘了25中包含两个5,125中包含3个5,以此类推 所以在找完1-n中先找5,再找25,再找125.. ...