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( ...
随机推荐
- 20201213-1 HTML基本标签(一)
> HTML 基本结构 <> </> 标签对 > 一个 HTML 文档由 4 个基本部分组成: 文档声明:<!DOCTYPE HTML>声明这是一个 ...
- mysqldump: [ERROR] unknown variable 'database=test'.
背景: 导出数据库test库的test表数据出现报错信息:mysqldump: [ERROR] unknown variable 'database=test'. 原来是my.cnf参数文件配置了以下 ...
- php项目从github自动pull到服务器
php项目github自动pull到服务器 项目名:web 一.自动触发 1.在服务器添加脚本文件:gitpull.sh #!/bin/sh cd /www/web git reset --hard ...
- Docker(一):Docker安装
简介 Docker是dotcloud公司开源的一款产品,主要基于PAAS平台为开发者提供服务.是解决运行环境和配置问题软件容器,方便做持续集成并有助于整体发布的容器虚拟化技术. Docker组件 ...
- java.net.BindException:Problem binding to [hostname:8088]地址已在使用
异常提示端口号被占用 查找被占用的端口 netstat -tln netstat -tln | grep 8083 netstat -tln ## 查看端口使用情况,而netstat -tln | g ...
- 搜索引擎优化(SEO)解决方案
搜索引擎优化(SEO)解决方案 在此之前,希望大家能重新审视搜索引擎,通俗来讲就是我们日常所用的百度.谷歌.搜狗.雅虎等.磨刀不误砍柴工,知己知彼,百战不殆! 一.搜索引擎是什么? 搜索引擎(Se ...
- kickstart+pxe部署
------------恢复内容开始------------ kickstart 通过网络安装系统 ----pxe kickstart,cobbler pex 预启动执行环境 通过网络接口启动计算机, ...
- 磁盘IO工作机制
磁盘IO工作机制 ref: <深入分析java web 技术内幕> by:许令波 几种访问文件的方式 文件读取和写入的 IO 操作都是调用操作系统提供的接口,因为磁盘设备是由操作系统管理的 ...
- [leetcode]49. Group Anagrams重排列字符串分组
是之前的重排列字符串的延伸,判断是重排列后存到HashMap中进行分组 这种HashMap进行分组的方式很常用 public List<List<String>> groupA ...
- 批量修改vsphere共享存储多路径选择策略
传统方式修改存储的多路径选择策略 首先说一下传统web界面操作方式: 可以看到至少需要6次才能修改完成一个.在生产环境中一般会挂载很多FC存储,这时候就需要一个批量快捷的方式来修改. 使用Powerc ...