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);
    }
}
相关推荐
ejjdhdjdjdjdjjsl2 分钟前
C#文件流操作技巧
java·开发语言·spring
虾说羊3 分钟前
HashMap详解
java
lkbhua莱克瓦2413 分钟前
反射3-反射获取构造方法
java·开发语言·反射
wanghowie23 分钟前
02.04.01 Java Stream API 进阶指南:从底层实现到性能优化
java·开发语言·性能优化
专注于大数据技术栈28 分钟前
java学习--Date
java·学习
YGGP38 分钟前
【Golang】LeetCode 5. 最长回文子串
算法·leetcode
青莲84338 分钟前
Java基础篇——第三部
java·前端
这周也會开心44 分钟前
Map集合的比较
java·开发语言·jvm
while(1){yan}1 小时前
SpringIoc
java·spring boot·spring·java-ee