美文网首页
LeetCode 第332题:重新安排行程

LeetCode 第332题:重新安排行程

作者: 放开那个BUG | 来源:发表于2020-09-23 21:37 被阅读0次

    1、前言

    题目描述

    2、思路

    本题是求有向图的欧拉路径,严谨地说,一个连通有向图 G 有欧拉路径,指存在一个顶点,从它出发,沿着有向边的方向,可以不重复地遍历图中所有的边。

    这里真的要加粗说明:这里我们使用 Map<String, List<String>> 的结构,其实就是用领接表来表示图,String 为图的某个顶点,List<String> 为这个图相邻的所有的顶点,即可以表示边(这里是不考虑使用边的情况,即我们只是根据顶点模拟边,没有使用边)。领接表的表示方法如下图所示,简直一模一样(上次那道拓扑排序的题,图的表示也是这样):

    领接表

    3、代码

    class Solution {
        public List<String> findItinerary(List<List<String>> tickets) {
            // 使用链表进行逆序插入
            List<String> ans = new LinkedList<>();
            if(tickets == null || tickets.size() == 0){
                return ans;
            }
    
            Map<String, List<String>> graph = new HashMap<>();
            for(List<String> pair : tickets){
                // List<String> nbr = graph.get(pair.get(0));
                // if(nbr == null){
                //     graph.put(pair.get(0), new LinkedList<>());
                // }else{
                //     nbr.add(pair.get(1));
                //     graph.put(pair.get(0), nbr);
                // }
                List<String> nbr = graph.computeIfAbsent(pair.get(0), k -> new LinkedList<>());
                nbr.add(pair.get(1));
            }
    
            // 按照目地顶点排序
            graph.values().forEach(x -> x.sort(String :: compareTo));
            visit(graph, "JFK", ans);
            return ans;
        }
    
        // DFS 方式遍历图,走到不能走为止,再将节点加入答案
        private void visit(Map<String, List<String>> graph, String src, List<String> ans){
            List<String> nbr = graph.get(src);
            while(nbr != null && nbr.size() > 0){
                String dest = nbr.remove(0);
                visit(graph, dest, ans);
            }
    
            // 逆序插入
            ans.add(0, src);
        }
    }
    

    相关文章

      网友评论

          本文标题:LeetCode 第332题:重新安排行程

          本文链接:https://www.haomeiwen.com/subject/zjwddktx.html