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);
    }
}
相关推荐
笃行客从不躺平几秒前
Spring Boot 的全局异常处理机制复习
java·spring boot·后端
程序员老徐1 分钟前
Tomcat源码分析一(Tomcat目录和配置文件说明)
java·tomcat·firefox
峰回路转之后1 分钟前
获取数据状态最大且更新时间最新的数据四种排序方式
java·开发语言
小园子的小菜2 分钟前
Token自动续期技术方案全解析:原理、优缺点与生产实践
java·后端·架构·状态模式
万物挽挽7 分钟前
饿汉式单例和懒汉式单例的区别是什么?
java
气π7 分钟前
【JavaWeb】——帝可得实践项目-App与设备端补充
java·spring boot·mybatis
Wpa.wk8 分钟前
接口测试-多层嵌套响应处理-JSONPath使用(Java版)
java·前端·经验分享·python·测试工具·jsonpath
这周也會开心10 分钟前
SpringBoot项目部署
java·spring boot·后端
Yu_iChan11 分钟前
苍穹外卖Day04 套餐管理
java
zhaokuner12 分钟前
16-现代架构扩展-DDD领域驱动设计
java·开发语言·设计模式·架构