力扣 332. 重新安排行程

一、题目描述

给你一份航线列表 tickets,其中 tickets[i] = [fromi, toi] 表示飞机出发和降落的机场地点。请你对该行程进行重新规划排序。

所有这些机票都属于一个从 JFK(肯尼迪国际机场)出发的先生,所以该行程必须从 JFK 开始。如果存在多种有效的行程,请你按字典排序返回最小的行程组合。

  • 例如,行程 ["JFK", "LGA"]["JFK", "LGB"] 相比就更小,排序更靠前。

假定所有机票至少存在一种合理的行程。且所有的机票必须都用一次只能用一次

示例 1:
输入:tickets = [["MUC","LHR"],["JFK","MUC"],["SFO","SJC"],["LHR","SFO"]]
输出:["JFK","MUC","LHR","SFO","SJC"]示例 2:
输入:tickets = [["JFK","SFO"],["JFK","ATL"],["SFO","ATL"],["ATL","JFK"],["ATL","SFO"]]
输出:["JFK","ATL","JFK","SFO","ATL","SFO"]
解释:另一种有效的行程是 ["JFK","SFO","ATL","JFK","ATL","SFO"] ,但是它字典排序更大更靠后。

二、题解

通过回溯法求解,因为要求最优解,因此在回溯前需要进行排序,同时在得到第一个满足条件的解后直接返回,因为排序后的第一个解即为最优解。

class Solution {
public:vector<string> result = {"JFK"};unordered_map<string, int> src_index_map;vector<string> findItinerary(vector<vector<string>> &tickets) {/* 记录每张机票的使用情况 */vector<bool> records(tickets.size(), false);/* 按照字典序对机票进行排序 */sort(tickets.begin(), tickets.end(), my_cmp);/* 通过哈希表记录每张机票出发机场在数组中的位置,避免重复遍历 */for (int i = 0; i < tickets.size(); i++) {if (i > 0 && tickets.at(i).at(0) == tickets.at(i - 1).at(0)) { continue; }src_index_map.emplace(tickets.at(i).at(0), i);}backtracking(tickets, records, "JFK");return result;}void backtracking(vector<vector<string>> &tickets, vector<bool> &records, string src) {if (result.size() == tickets.size() + 1) { return;}auto ans = src_index_map.find(src);if (ans != src_index_map.end()) { for (int begin = ans->second; begin < tickets.size() && src == tickets.at(begin).at(0); begin++) {if (!records.at(begin)) { result.emplace_back(tickets.at(begin).at(1));records.at(begin) = true;backtracking(tickets, records, tickets.at(begin).at(1));/* 只需要字典序最小的情况,因此满足条件后直接返回 */if (result.size() == tickets.size() + 1) { return; }result.pop_back();records.at(begin) = false;}}}}static bool my_cmp(vector<string> &a, vector<string> &b) {if (a.at(0) == b.at(0)) {return a.at(1) < b.at(1);} else {return a.at(0) < b.at(0);}}
};

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/5070.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leetcode_167两数之和II

1. 题目 两数之和II 2. 题意 有序数组&#xff0c;找到两数和为一固定值的两数下标。要求只能用到常数的空间。 3. 题解 与两数之和的区别是排好序了&#xff0c;且不能用额外的空间。即不能使用哈希表了&#xff0c;二重循环时间复杂度会超。 3.1 二分 固定指针左端&am…

通过定时任务+sh脚本方式实现服务器日志文件异机备份

需求&#xff1a; 等保要求服务器A日志(服务器、数据库、后端、nginx、redis等)备份在另外一台服务器B上 实现原理 通过定时任务sh脚本scp命令&#xff0c;实现定时执行脚本&#xff0c;将文件备份到另外一台服务器上 例子&#xff1a; step1、准备工作 服务器A ipA 服务…

CMake 学习笔记(子目录 续)

这篇博客接着上篇。我们的目录结构和上一个例子完全相同。 CMakeLists.txt MathFunctions|- CMakeLists.txt|- MathFunctions.cxx|- MathFunctions.h|- mysqrt.cxx|- mysqrt.htutorial.cxx TutorialConfig.h.in在上一个例子中&#xff0c;为了包含 MathFunctions 库。我们在最…

区块链:哈希算法与一致性哈希算法

本篇主要介绍区块链中常用到的哈希算法。 1 哈希算法 1.1 定义及特性 哈希算法是指通过哈希函数(Hash Function)对任意长度的输入数据(比如文件、消息、数字等)进行转换&#xff0c;生成一个固定长度的哈希值(Hash Value)的过程。   在区块链中&#xff0c;哈希算法常用于区…

蓝桥杯上岸每日N题 第一期(一)!!!

大家好 我是寸铁&#x1f4aa; 考前需要刷大量真题,大家一起相互监督&#xff0c;每日做N题&#xff0c;一起上岸吧✌️ ~ 第一期(一) 题目&#xff1a;回文日期 ✨ 考点&#xff1a;枚举模拟 &#x1f4aa; 该题目类型会同时收录在相关复习专题&#xff0c;供大家学习 收…

计算机网络基础-OSI七层模型 和 TCP/IP四层模型的对比

OSI七层模型 和 TCP/IP四层模型的对比 OSI七层模型&#xff1a; 理论上的网络通信模型 记忆&#xff1a; (物、链、网、输、会、示、用) TCP/IP四层模型&#xff1a; 实际上的网络通信标准 (1) 七层网络体系结构各层的主要功能&#xff1a; 应用层&#xff1a; 最上层的&am…

Nginx配置整合:基本概念、命令、反向代理、负载均衡、动静分离、高可用

一、基本概念 1.什么是Nginx Nginx是一个高性能的HTTP和反向代理服务器&#xff0c;也是一个IMAP/POP3/SMTP代理server。其特点是占有内存少。并发能力强&#xff0c;其并发能力确实在同类型的网页server中表现较好。 http服务器 Web服务器是指驻留于因特网上某种类型计算机的程…

请问支付功能如何测试

目录 01测试思维 02支付功能的测试点 一&#xff1a;支付的分类&#xff1a; 二&#xff1a;功能测试 三&#xff1a;接口测试 四&#xff1a;安全测试 五&#xff1a;测试点 01测试思维 要分析测试点之前&#xff0c;我们先来梳理一下测试思维。总结来说&#xff0c;任…

IP首部报文字段

一、IP首部报文字段 字段如下图所示 二、每个字段的含义 版本 表示 IP 协议的版本。通信双方使用的 IP 协议版本必须一致。目前广泛使用的IP协议版本号为 4&#xff0c;即 IPv4 首部长度 这个字段所表示数的单位是 32 位字长&#xff08;1 个 32 位字长是 4 字节&#xff0…

分布式事务 Seata

分布式事务 Seata 事务介绍分布式理论Seata 介绍Seata 部署与集成Seata TC Server 部署微服务集成 Seata XA 模式AT 模式AT 模式执行过程读写隔离写隔离读隔离 实现 AT 模式 TCC 模式TCC 模式介绍实现 TCC 模式 Saga 模式Seata 四种模式对比 事务介绍 事务&#xff08;Transac…

uniapp引入echarts

作为前端在开发需求的时候经常会遇到将数据展示为图表的需求&#xff0c;之前一直用的HBuilder的图表插件uCharts&#xff0c;使用方法可以参考我的另一篇博客&#xff1a;uniapp 中使用图表&#xff08;秋云uCharts图表组件&#xff09; 但是最近发现uCharts很多功能都需要付…

Bard:一个可以描述图像的人工智能

Bard 是一个大型语言模型&#xff0c;可以对各种提示和问题进行交流和生成类似人类的文本。它接受了大量的文字和代码训练&#xff0c;可以生成文本、翻译语言、编写不同类型的创意内容&#xff0c;并以信息丰富的方式回答你的问题。 Bard 还可以识别图像。它可以识别图像中的…

代理IP、Socks5代理、SK5代理与网络安全:保护隐私与防御威胁的技术探索

随着数字化时代的到来&#xff0c;网络安全和个人隐私保护日益成为重要议题。代理IP、Socks5代理和SK5代理作为关键技术手段&#xff0c;为用户提供了保护隐私、提高网络安全性和防御网络威胁的解决方案。本文将深入探讨这些代理技术的原理、特点以及它们与网络安全的紧密联系。…

数组的递归筛选

数组递归筛选 根据一个值筛选出来通过 includes 递归 const options [{name: "ikun",options: [{name: "YAY11",},],},{name: "YAY",}, ];function findValue(orgOptions,val) {let newArr1 []orgOptions.forEach(item>{if(item.options…

ASUS华硕无双15_K3502ZA工厂模式原装Win11恢复原厂OEM预装系统 带ASUS Recovey恢复功能

ASUS华硕无双15笔记本电脑12代Vivobook_ASUSLaptop K3502ZA出厂Windows11系统工厂包 自带恢复功能、所有驱动、出厂主题壁纸LOGO、Office办公软件、MyASUS等预装程序 所需要工具&#xff1a;32G或以上的U盘 文件格式&#xff1a;HDI,SWP,OFS,EDN,KIT,TLK多个底包 文件大小&…

leetcode 40. 组合总和 II

2023.7.19 此题为 组合总和 的升级版。本题的特殊之处在于 给定的candidates数组只一个无序且包含重复元素的数组&#xff0c;并且最终的解集不能包含重复的组合。 所以本题的关键在于去重。那么&#xff0c;此类题的去重分为两种&#xff0c;一种是解集内部去重&#xff0c;灵…

Spring Boot学习

Spring Boot 配置 同一目录下配置文件优先级&#xff1a;.properties > .yml > .yaml 错误&#xff1a;org.yaml.snakeyaml.error.YAMLException: java.nio.charset.MalformedInputException: Input length 1 Caused by: java.nio.charset.MalformedInputException: Inp…

VUE- 选取本地图片,自定义裁切图片比例 vue-cropper

裁切图片&#xff0c;按照比例裁切&#xff0c;分步骤 1&#xff1a;el-upload选择本地图片&#xff08;分选择本地和上传两步骤&#xff09; 2&#xff1a;在on-change回调方法中拿到el-upload选中的图片&#xff0c;显示在vueCropper上&#xff08;&#xff09;。 2.1&…

查看IP地址方法(电脑IP地址方法)

查看IP地址方法 如何识别win7还是win10系统&#xff1f; &#xff08;一&#xff09;Win7系统电脑导航栏如下&#xff1a; &#xff08;二&#xff09;Win10系统电脑导航栏如下&#xff1a; 一、win7系统查看IP地址 方法一&#xff1a;查看网络设置 点击电脑导航栏最右下…

react和vue2/3父子组件的双向绑定(sync、emit、v-model)

目录 Vue .sync&#xff08;2.3.0&#xff09; $emit &#xff08;2.3后&#xff09; 自定义组件的 v-model 2.2.0 v-modelemits(3.0取消了.sync) React 父组件回调函数 相关基础 框架 MVC &#xff08;Model View Controller&#xff09;/MVP&#xff08;Model View…