用二进制表示获得的钥匙,假设n=钥匙个数
000000000代表没有钥匙,0000000001代表有idx为1的钥匙,0000000011代表有idx=1,2的钥匙
(这方法巧妙又复杂..
代码:
- class Solution {
- static int[][] dirs = {{-1,0},{1,0},{0,-1},{0,1}};
- public int shortestPathAllKeys(String[] grid) {
- int m = grid.length, n = grid[0].length();
- int startx = 0,starty = 0;
- Map
keyToIndex = new HashMap<>(); - //存钥匙的字母和对应的idx序号
- for(int i=0;i
- for(int j=0;j
- if(grid[i].charAt(j)=='@'){
- startx = i;
- starty = j;
- }else if(Character.isLowerCase(grid[i].charAt(j))){
- if(!keyToIndex.containsKey(grid[i].charAt(j))){
- int idx = keyToIndex.size();
- keyToIndex.put(grid[i].charAt(j), idx);
- }
- }
- }
- }
- Queue<int[]> queue = new ArrayDeque<int[]>();
- int[][][] dist = new int[m][n][1<
- //第三维是2的size次方 列举钥匙的所有可能
- for(int i=0;i
- for(int j=0;j
- Arrays.fill(dist[i][j],-1);
- }
- }
- queue.offer(new int[]{startx,starty,0});
- dist[startx][starty][0] = 0;
- while(!queue.isEmpty()){
- int[] arr = queue.poll();
- int x = arr[0],y = arr[1],mask = arr[2];//mask是钥匙的排列
- for(int i=0;i<4;i++){
- int nx = x + dirs[i][0];
- int ny = y + dirs[i][1];
- if(nx>=0 && nx
=0 && ny'#'){ - if(grid[nx].charAt(ny)=='.'||grid[nx].charAt(ny)=='@'){
- if(dist[nx][ny][mask] == -1){
- dist[nx][ny][mask] = dist[x][y][mask]+1;
- queue.offer(new int[]{nx,ny,mask});
- }
- }else if(Character.isLowerCase(grid[nx].charAt(ny))){
- int idx = keyToIndex.get(grid[nx].charAt(ny));
- if(dist[nx][ny][mask|(1<
1){ - dist[nx][ny][mask|(1<
1; - if((mask|(1<
1<1){ - return dist[nx][ny][mask|(1<
- }
- queue.offer(new int[]{nx,ny,mask|(1<
- }
- }else{
- int idx = keyToIndex.get(Character.toLowerCase(grid[nx].charAt(ny)));
- if((mask&(1<
0&&dist[nx][ny][mask]==-1){ - dist[nx][ny][mask] = dist[x][y][mask]+1;
- queue.offer(new int[]{nx,ny,mask});
- }
- }
- }
- }
-
- }
- return -1;
- }
- }
-
相关阅读:
最新最全计算机专业毕业设计选题精华汇总-持续更新中
【高等数学基础进阶】导数与微分
uni-app 的条件编译(APP-PLUS 、H5、MP-WEIXIN )
Java 在Word文档中添加艺术字
CANoe-vTESTstudio之Test Diagram编辑器(功能介绍)
Excel的Index+MATCH组合使用方法
中国移动云能力中心(苏小研)--秋招面经(已offer)
Transformer模型:Encoder的self-attention mask实现
windows下C++管道通信
如何提高App开发效率?低代码平台值得一试
-
原文地址:https://blog.csdn.net/stacey777/article/details/133085166