前言
###我做这类文章一个重要的目的还是给正在学习的大家提供方向和记录学习过程(例如想要掌握基础用法,该刷哪些题?)我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!
习题
1.迷宫中离入口最近的出路
题目链接: 1926. 迷宫中离入口最近的出口 - 力扣(LeetCode)
题面:
代码:
java
class Solution {
int[][] dirs = {{1,0},{-1,0},{0,1},{0,-1}};
public int nearestExit(char[][] maze, int[] entrance) {
int n = maze.length;
int m = maze[0].length;
Queue<int[]> queue = new LinkedList<>();
queue.offer(entrance);
maze[entrance[0]][entrance[1]] = '+';
int count = 0;
while(queue.size()!=0){
count++;
int size = queue.size();
for(int i = 0;i<size;i++){
int[] arr =queue.poll();
int x = arr[0];
int y = arr[1];
for(int[] brr:dirs){
int nx = x+brr[0];
int ny = y+brr[1];
if(nx>=0&&nx<=n-1&&ny>=0&&ny<=m-1&&maze[nx][ny]=='.'){
if(nx==0||nx==n-1||ny==0||ny==m-1)return count;
queue.offer(new int[]{nx,ny});
maze[nx][ny]='+';
}
}
}
}
return -1;
}
}
后言
上面是力扣图论专题,下一篇是其他的习题,希望有所帮助,一同进步,共勉!