Java | Leetcode Java题解之第332题重新安排行程

题目:

题解:

java 复制代码
class Solution {
    Map<String, PriorityQueue<String>> map = new HashMap<String, PriorityQueue<String>>();
    List<String> itinerary = new LinkedList<String>();

    public List<String> findItinerary(List<List<String>> tickets) {
        for (List<String> ticket : tickets) {
            String src = ticket.get(0), dst = ticket.get(1);
            if (!map.containsKey(src)) {
                map.put(src, new PriorityQueue<String>());
            }
            map.get(src).offer(dst);
        }
        dfs("JFK");
        Collections.reverse(itinerary);
        return itinerary;
    }

    public void dfs(String curr) {
        while (map.containsKey(curr) && map.get(curr).size() > 0) {
            String tmp = map.get(curr).poll();
            dfs(tmp);
        }
        itinerary.add(curr);
    }
}
相关推荐
nbwenren33 分钟前
Springboot中SLF4J详解
java·spring boot·后端
wellc1 小时前
java进阶知识点
java·开发语言
灰色小旋风1 小时前
力扣合并K个升序链表C++
java·开发语言
_MyFavorite_1 小时前
JAVA重点基础、进阶知识及易错点总结(28)接口默认方法与静态方法
java·开发语言·windows
Kk.08021 小时前
力扣 LCR 084.全排列||
算法·leetcode·职场和发展
旖-旎1 小时前
分治(快速选择算法)(3)
c++·算法·leetcode·排序算法·快速选择
helx821 小时前
SpringBoot中自定义Starter
java·spring boot·后端
_MyFavorite_2 小时前
JAVA重点基础、进阶知识及易错点总结(31)设计模式基础(单例、工厂)
java·开发语言·设计模式
_日拱一卒2 小时前
LeetCode:合并区间
算法·leetcode·职场和发展
ILYT NCTR2 小时前
SpringSecurity 实现token 认证
java