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);
    }
}
相关推荐
独处东汉1 分钟前
freertos开发空气检测仪之输入子系统按键驱动测试
android·java·数据库
Cult Of1 分钟前
一个最小可扩展聊天室系统的设计与实现(Java + Swing + TCP)(2)
java·jvm·tcp/ip
allway24 分钟前
统信UOS桌面专业版开启 ROOT权限并设置 SSH 登录
java·数据库·ssh
努力学算法的蒟蒻6 分钟前
day70(1.29)——leetcode面试经典150
算法·leetcode·面试
别会,会就是不问7 分钟前
Junit4下Mockito包的使用
java·junit·单元测试
好好沉淀8 分钟前
Java 开发环境概念速查笔记(JDK / SDK / Maven)
java·笔记·maven
凹凸曼coding8 分钟前
Java业务层单元测试通用编写流程(Junit4+Mockito实战)
java·单元测试·log4j
C雨后彩虹14 分钟前
Java 并发程序性能优化:思路、方法与实践
java·线程·多线程·并发
!停16 分钟前
数据结构空间复杂度
java·c语言·算法
她说..18 分钟前
验签实现方案整理(签名验证+防篡改+防重放)
java·经验分享·spring boot·java-ee·bladex