鱼C论坛

 找回密码
 立即注册
查看: 1384|回复: 0

[技术交流] LeetCode 1345. 跳跃游戏 IV

[复制链接]
发表于 2020-3-3 16:46:13 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 798236606 于 2020-3-5 10:12 编辑

传送门:https://leetcode-cn.com/problems/jump-game-iv/

BFS + 哈希表剪枝
class Solution {
public:
    int minJumps(vector<int>& arr) {
        //这一步for循环可以不加,可以规避掉大量连续相同值造成的时间浪费
        for (int i = 1; i < arr.size() - 1; ++i)
        {
            int j  = i + 1; 
            
            while (j < arr.size() && arr[j] == arr[i]) ++j;
            arr.erase(arr.begin() + i + 1, arr.begin() + j);
        }

        struct Node{
            int id, step;
        };        

        int n = arr.size();
        unordered_map<int, vector<int>> m;
        
        for (int i = 0; i < n; ++i) m[arr[i]].push_back(i);

        vector<bool> vis(n, false);
        queue<Node> q;
        
        q.push({0, 0});
        vis[0] = true;
        
        while (!q.empty())
        {
            Node now = q.front();
            q.pop();
            
            if (now.id == arr.size() - 1) return now.step;
            
            if (!vis[now.id + 1])
            {
                q.push({now.id + 1, now.step + 1});
                vis[now.id + 1] = true;
            }
            
            if (now.id > 0 && !vis[now.id - 1]) 
            {
                q.push({now.id - 1, now.step + 1});
                vis[now.id - 1] = true;
            }

            if (m.find(arr[now.id]) != m.end())
            {
                for (int i: m[arr[now.id]])
                {
                    if (!vis[i])
                    {
                        q.push({i, now.step + 1}); 
                        vis[i] = true;
                    }                    
                }

                m.erase(m.find(arr[now.id]));//找到一个相同值,则所有同值的位置都不可再通过同值的规则跳             
            }
        }
        
        return -1;//若未找到路径,返回-1
    }
};
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-15 23:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表