[Leetcode] 505. The Maze II 解题报告

来源:互联网 发布:淘宝怎么设置花呗付款 编辑:程序博客网 时间:2024/05/16 02:34

题目

There is a ball in a maze with empty spaces and walls. The ball can go through empty spaces by rolling updownleft 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.

Example 1

Input 1: a maze represented by a 2D array0 0 1 0 00 0 0 0 00 0 0 1 01 1 0 1 10 0 0 0 0Input 2: start coordinate (rowStart, colStart) = (0, 4)Input 3: destination coordinate (rowDest, colDest) = (4, 4)Output: 12Explanation: One shortest way is : left -> down -> left -> down -> right -> down -> right.             The total distance is 1 + 1 + 3 + 1 + 2 + 2 + 2 = 12.

Example 2

Input 1: a maze represented by a 2D array0 0 1 0 00 0 0 0 00 0 0 1 01 1 0 1 10 0 0 0 0Input 2: start coordinate (rowStart, colStart) = (0, 4)Input 3: destination coordinate (rowDest, colDest) = (3, 2)Output: -1Explanation: There is no way for the ball to stop at the destination.

Note:

  1. There is only one ball and one destination in the maze.
  2. Both the ball and the destination exist on an empty space, and they will not be at the same position initially.
  3. The given maze does not contain border (like the red rectangle in the example pictures), but you could assume the border of the maze are all walls.
  4. The maze contains at least 2 empty spaces, and both the width and height of the maze won't exceed 100.

思路

这种求最短路径的题目一般还是BFS比DFS靠谱一些。下面的代码是在[Leetcode] 490. The Maze 解题报告的基础上修改而来的。我们用一个map来记录已经访问过的位置以及其对应的最短路径。然后维护一个队列。每次取出队列头部,如果发现是destination了,就更新最终结果;否则就朝着四个方向前进直到到达障碍或者边界。此时如果发现结尾点的路径还要长一些,就需要进队列再次进行搜索了。当然本题目也可以不用map而直接用二维数组记录当前的各个位置上的搜索路径,虽然可能空间复杂度更高一些,但是时间复杂度会有所下降。

代码

class Solution {public:    int shortestDistance(vector<vector<int>>& maze, vector<int>& start, vector<int>& destination) {        map<vector<int>, int> visited;        vector<vector<int>> dirs = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}};        int ret = INT_MAX;        visited[start] = 0;        queue<vector<int>> q;        q.push(start);        while (!q.empty()) {            vector<int> pos = q.front();            q.pop();            if (pos == destination) {                ret = min(ret, visited[pos]);            }            else {                for (int i = 0; i < 4; ++i) {                    vector<int> res = go2End(maze, pos, dirs[i]);                    int line_length = i <= 1 ? abs(pos[1] - res[1]) : abs(pos[0] - res[0]);                    if (visited.find(res) == visited.end() || visited[res] > visited[pos] + line_length) {                        visited[res] = visited[pos] + line_length;                        q.push(res);                    }                }            }        }        return ret == INT_MAX ? -1 : ret;    }private:    vector<int> go2End(vector<vector<int>> &maze, vector<int> start, vector<int> &dir) {        vector<int> new_start = {start[0] + dir[0], start[1] + dir[1]};        int row_num = maze.size(), col_num = maze[0].size();          if(new_start[0] < 0 || new_start[0] >= row_num ||            new_start[1] < 0 || new_start[1] >= col_num ||             maze[new_start[0]][new_start[1]] == 1) {             // already at the end            return start;          }        return go2End(maze, new_start, dir);    }};

阅读全文
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 狗狗耳朵受伤了怎么办 狗狗的耳朵发热怎么办 头疼带的耳朵疼怎么办 戴眼镜压耳朵疼怎么办 偏头神经跳疼怎么办 脸消肿后有硬块怎么办 拔完智齿好疼怎么办 补过的牙裂了怎么办 补牙后吃冷热疼怎么办 假体下巴肿疼怎么办 左脸疼痛张嘴疼怎么办 一张嘴脸颊会痛怎么办 法斗地包天怎么办 皮肤起小水泡痒怎么办 手臂起小水泡痒怎么办 手背有小水泡痒怎么办 水泡破了很痒怎么办 有一块牙龈肿了怎么办 耳前瘘管有脓怎么办 睡歪脖子很痛怎么办 睡歪脖子怎么办小妙招 睡觉睡得脖子疼怎么办 睡久了后脑勺疼怎么办 腮帮肿了但不疼怎么办 吃硬东西腮帮痛怎么办 嘴巴长开旁边疼怎么办 晚上腿酸睡不着觉怎么办 吃酸的牙齿酸软怎么办 吃酸东西牙齿酸怎么办 拔完智齿神经疼怎么办 22岁腿关节疼痛怎么办 耳洞里面有硬块怎么办 耳洞发炎有硬块怎么办 小孩慢性扁桃体发炎怎么办大全 侧切伤口化脓了怎么办 狗狗伤口不愈合怎么办 狗后腿烂了化脓怎么办 乳腺增生腋下淋巴结肿大怎么办 手术刀口冒脓了怎么办 脚伤口感染肿了怎么办 皮外伤口不愈合怎么办