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( ...
随机推荐
- sqlplus、lsnrctl命令工具不可用(libclntsh.so.11.1)
原因: libclntsh.so.11.1文件丢失了 解决方法: 在其他机器把这个文件拷贝到目标库安装目录底下的lib目录即可
- Elastic Search 学习之路(三)—— tutorial demo
一.ElasticSearch tutorial demo example 1. 单机.local.CRUD操作 实现方式: SpringBoot + ElasticSearch 拷贝的小demo,原 ...
- centos 7 yum 安装 python3
sudo yum install epel-release sudo yum install python34参考:http://stackoverflow.com/questions/8087184 ...
- strin 字符串的内置函数
count("x")统计字符串的元素的个数 a = "hello kitty" print (a.count("t"))#统计t出现的个数 ...
- 在linux下搭建NFS服务器实现文件共享
目录 一.关于NFS 二.搭建一台NFS服务器共享特定资源 三.调优 一.关于NFS 1.NFS是Network File System的简写,即网络文件系统.网络文件系统是FreeBSD支持的文件系 ...
- 图解JanusGraph系列 - 关于JanusGraph图数据批量快速导入的方案和想法(bulk load data)
大家好,我是洋仔,JanusGraph图解系列文章,实时更新~ 图数据库文章总目录: 整理所有图相关文章,请移步(超链):图数据库系列-文章总目录 源码分析相关可查看github(码文不易,求个sta ...
- P4735 最大异或和 01 Trie
题目描述 给定一个非负整数序列 \(\{a\}\),初始长度为\(n\). 有 \(m\) 个操作,有以下两种操作类型: \(A\ x\):添加操作,表示在序列末尾添加一个数 \(x\),序列的长度 ...
- Python爬取热搜存入数据库并且还能定时发送邮件!!!
一.前言 微博热搜榜每天都会更新一些新鲜事,但是自己处于各种原因,肯定不能时刻关注着微博,为了与时代接轨,接受最新资讯,就寻思着用Python写个定时爬取微博热搜的并且发送QQ邮件的程序,这样每天可以 ...
- iOS 14 YYAnimatedImageView加载图片失败处理
1.问题出在YYAnimatedImageView源码一个方法中 - (void)displayLayer:(CALayer *)layer { if (_curFrame) { layer.cont ...
- (十五)、linux软件的安装与查询-rpm与yum命令
一.RPM软件管理程序:rpm 1.RPM安装软件(install) rpm命令的选项超级多,安装话直接使用-ivh即可,其余做了解即可 命令格式:rpm -ivh package_name.rp ...