代码随想录 Leetcode332. 重新安排行程

题目:


代码(首刷看解析 2024年2月6日):

cpp 复制代码
class Solution {
private:
    unordered_map<string,map<string,int>> targets;
public:
    bool backtracking(int tickNum, vector<string>& res) {
        if (tickNum == res.size() - 1) {
            return true;
        }
        for (pair<const string,int>& target : targets[res[res.size() - 1]]) {
            if (target.second > 0) {
                res.push_back(target.first);
                target.second--;
                if (backtracking(tickNum, res)) return true;
                target.second++;
                res.pop_back();
            }
        }
        return false;
    }
    vector<string> findItinerary(vector<vector<string>>& tickets) {
        targets.clear();
        vector<string> res;
        for (const vector<string>& vec : tickets) {
            targets[vec[0]][vec[1]]++;
        }
        res.push_back("JFK");
        backtracking(tickets.size(), res);
        return res;
    }
};
相关推荐
方案开发PCBA抄板芯片解密9 小时前
什么是算法:高效解决问题的逻辑框架
算法
songx_9910 小时前
leetcode9(跳跃游戏)
数据结构·算法·游戏
小白狮ww10 小时前
RStudio 教程:以抑郁量表测评数据分析为例
人工智能·算法·机器学习
AAA修煤气灶刘哥10 小时前
接口又被冲崩了?Sentinel 这 4 种限流算法,帮你守住后端『流量安全阀』
后端·算法·spring cloud
kk”11 小时前
C语言快速排序
数据结构·算法·排序算法
纪元A梦11 小时前
贪心算法应用:基因编辑靶点选择问题详解
算法·贪心算法
3壹11 小时前
数据结构精讲:栈与队列实战指南
c语言·开发语言·数据结构·c++·算法
skytier12 小时前
Construct内报错和定位解决
算法
skytier12 小时前
Ascend print数据落盘使用
算法
etcix12 小时前
dmenux.c: integrate dmenu project as one file
c语言·前端·算法