[LC] 505. The Maze II
There is a ball in a maze with empty spaces and walls. The ball can go through empty spaces by rolling up, down, left or right, but it won't stop rolling until hitting a wall. When the ball stops, it could choose the next direction.
Given the ball's start position, the destination and the maze, find the shortest distance for the ball to stop at the destination. The distance is defined by the number of empty spaces traveled by the ball from the start position (excluded) to the destination (included). If the ball cannot stop at the destination, return -1.
The maze is represented by a binary 2D array. 1 means the wall and 0 means the empty space. You may assume that the borders of the maze are all walls. The start and destination coordinates are represented by row and column indexes.
 class Solution {
     public int shortestDistance(int[][] maze, int[] start, int[] destination) {
         int row = maze.length;
         int col = maze[0].length;
         int res = 0;
         Queue<Cell> queue = new LinkedList<>();
         int[][] dists = new int[row][col];
         for (int[] dist: dists) {
             Arrays.fill(dist, -1);
         }
         queue.offer(new Cell(start[0], start[1]));
         dists[start[0]][start[1]] = 0;
         int[][] directions = new int[][]{{-1, 0}, {1, 0}, {0, -1}, {0, 1}};
         while (!queue.isEmpty()) {
             int size = queue.size();
                 Cell cur = queue.poll();
                 int curX = cur.x;
                 int curY = cur.y;
                 for (int[] direction: directions) {
                     int newX = curX;
                     int newY = curY;
                     int curDist = dists[curX][curY];
                     while (newX >= 0 && newX < row && newY >= 0 && newY < col && maze[newX][newY] == 0) {
                         newX += direction[0];
                         newY += direction[1];
                         curDist += 1;
                     }
                     newX -= direction[0];
                     newY -= direction[1];
                     curDist -= 1;
                     if (dists[newX][newY] == -1 || curDist < dists[newX][newY]) {
                         dists[newX][newY] = curDist;
                         queue.offer(new Cell(newX, newY));
                     }
                 }
         }
         return dists[destination[0]][destination[1]];
     }
 }
 class Cell {
     int x;
     int y;
     public Cell(int x, int y) {
         this.x = x;
         this.y = y;
     }
 }
[LC] 505. The Maze II的更多相关文章
- [LeetCode] 505. The Maze II 迷宫之二
		There is a ball in a maze with empty spaces and walls. The ball can go through empty spaces by rolli ... 
- LeetCode 505. The Maze II
		原题链接在这里:https://leetcode.com/problems/the-maze-ii/ 题目: There is a ball in a maze with empty spaces a ... 
- [LeetCode] 505. The Maze II 迷宫 II
		There is a ball in a maze with empty spaces and walls. The ball can go through empty spaces by rolli ... 
- 505. The Maze II
		原题链接:https://leetcode.com/articles/the-maze-ii/ 我的思路 在做完了第一道迷宫问题 http://www.cnblogs.com/optor/p/8533 ... 
- 【LeetCode】505. The Maze II 解题报告(C++)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 BFS 日期 题目地址:https://leetcod ... 
- A Dangerous Maze (II) LightOJ - 1395(概率dp)
		A Dangerous Maze (II) LightOJ - 1395(概率dp) 这题是Light Oj 1027的加强版,1027那道是无记忆的. 题意: 有n扇门,每次你可以选择其中一扇.xi ... 
- LightOJ - 1395 A Dangerous Maze (II) —— 期望
		题目链接:https://vjudge.net/problem/LightOJ-1395 1395 - A Dangerous Maze (II) PDF (English) Statistic ... 
- lintcode 787. The Maze 、788. The Maze II 、
		787. The Maze https://www.cnblogs.com/grandyang/p/6381458.html 与number of island不一样,递归的函数返回值是bool,不是 ... 
- LC 499. The Maze III 【lock,hard】
		There is a ball in a maze with empty spaces and walls. The ball can go through empty spaces by rolli ... 
随机推荐
- css  元素选择器
			子元素选择器 h1 > strong {color:red;} //这个规则会把第一个 h1 下面的两个 strong 元素变为红色,但是第二个 h1 中的 strong 不受影响: <h ... 
- JavaScript学习总结(四)
			这一部分我们继续介绍JavaScript的常用对象. Number对象 创建Number对象 方式1: var 变量= new Number(数字) 方式2: var 变量 = 数字; 常用的方法 t ... 
- 问:为什么java是单继承,但却是多实现的呢?
			在学习的过程中,我发现了如题的这个有趣的问题. 单继承不必解释,一个类只能有一个直接父类:但是对于接口的实现,一个类却能够实现多个接口. 为什么是这种情况呢?我们来举个简单的栗子看一下: class ... 
- Vus the Cossack and Strings(Codeforces Round #571 (Div. 2))(大佬的位运算实在是太强了!)
			C. Vus the Cossack and Strings Vus the Cossack has two binary strings, that is, strings that consist ... 
- java和数据库中所有的锁都在这了
			1.java中的锁 1.1 锁的种类 公平锁/非公平锁 可重入锁/不可重入 独享锁/共享锁 读写锁 分段锁 偏向锁/轻量级锁/重量级锁 自旋锁 1.2 锁详细介绍 1.2.1 公平锁,非公平锁 公平锁 ... 
- python-day5爬虫基础之正则表达式2
			dot: '.'匹配任意的字符 '*'匹配任意多个(0到多个) 如图所示, 程序运行结果是abc,之所以没有匹配\n,是因为\n是换行符,它就代表这个字符串是两行的,而正则表达式是一行一行去匹配的.在 ... 
- 《深入理解java虚拟机》-目录结构
			第一部分 走进Java第1章 走进Java 第二部分 自动内存管理机制 第2章 Java内存区域与内存溢出异常2.1 概述2.2 运行时数据区域2.2.1 程序计数器2.2.2 java虚拟机栈2.2 ... 
- JS控制 input 输入字符限制全搜集
			ENTER键可以让光标移到下一个输入框 <input onkeydown="if(event.keyCode==13)event.keyCode=9" > 只能是中文 ... 
- Angular ng-container ng-template 用法
			ng-container本身不创建任何html代码,相当于一个容器. <ng-container *ngFor="let item of dataSource;let i=index& ... 
- ansible批量部署模块(二)
			回顾:Ansible: 无需客户端程序 只要有SSH 模块化 ansible帮助工具ansible-doc 模块名ansible-doc 模块名 -s 列出该模块的所有选项ansible-doc -l ... 
