【LeetCode】Day201-重新安排行程
创始人
2024-05-14 12:42:04

题目

332.重新安排行程【困难】

题解

这道题的几个难点:

  1. 一个行程中,如果航班处理不好容易变成一个圈,成为死循环
  2. 有多种解法,字母序靠前排在前面,应该如何记录映射关系?
  3. 使用回溯法,终止条件是什么?
  4. 搜索的过程中,如何遍历一个机场所对应的所有机场?

如何理解死循环

如图情况,若没有处理好,可能在JFK和NRT之间形成死循环
在这里插入图片描述

如何记录映射关系

一个机场映射多个机场,机场之间要靠字母序排列,可以使用HashMap记录
定义如下:

Map>map:Map<出发机场,Map<到达机场,航班次数>>map

为什么一定要增删元素呢?因为出发机场和到达机场会重复,搜索的过程没及时删除目的机场就会死循环。

在遍历Map<出发机场,Map<到达机场,航班次数>>map过程中,可以使用“航班次数”这个字段做加减,来标记到达机场是否使用过了。

如果“航班次数”大于0,说明目的地还可以飞,如果“航班次数”等于0说明目的地不能飞了,而不用对集合做删除元素或者增加元素的操作。(相当于说我不删,我就做一个标记!

回溯法

递归树

在这里插入图片描述

回溯三部曲

  1. 递归函数参数
    使用Map<出发机场,Map<到达机场,航班次数>>map记录航班的映射关系

注意这里函数返回值是boolean!而不是通常用的void!

因为我们只需要找到一个行程,就是在树形结构中唯一一条通向叶子节点的路线,如上递归树所示。

  1. 递归终止条件
    回溯过程中遇到的机场个数,达到了(航班数量+1),就找到了一个行程,将所有航班串在一起了。
if(res.size()==n+1){return;
}
  1. 单层搜索过程
    回溯的过程中,如何遍历一个机场所对应的所有机场呢?
for (pair& target : targets[result[result.size() - 1]]) {if (target.second > 0 ) { // 记录到达机场是否飞过了result.push_back(target.first);target.second--;if (backtracking(ticketNum, result)) return true;result.pop_back();target.second++;}
}

完整代码

回溯法代码实在是太麻烦了,还是换成官方题解的“Hierholzer 算法" 了,用于在连通图中找欧拉路径

对于航班映射关系的存储和上面不同,对于java来说这种写法简便很多,也方便删除!

class Solution {Listres=new ArrayList<>();Map>map=new HashMap<>();//记录航班映射关系public List findItinerary(List> tickets){int n=tickets.size();//初始化航班映射关系for(Listticket:tickets){String src=ticket.get(0),dest=ticket.get(1);//首次存入新建优先队列if(!map.containsKey(src))map.put(src,new PriorityQueue<>());map.get(src).add(dest);}//深搜dfs("JFK");Collections.reverse(res);//最先找到的是最深的不能再走的目的地,所以要反转过来return res;}public void dfs(String src){//当传入的参数是始发地而且还有边的时候,取边出队删除并且继续递归深搜这条边的点,一直到不能再走再返回while(map.containsKey(src)&&map.get(src).size()>0)dfs(map.get(src).poll());res.add(src);}
}

时间复杂度:O(mlogm)O(mlogm)O(mlogm),m是边的数量,对于每一条边需要O(logm)删除它。

空间复杂度:O(m)O(m)O(m),需要存储每一条边。

p.s 最近一直在攻回溯,在二刷有些题,力扣系列都没有更新
p.p.s 力扣终于刷到300题了!按理说一天一道应该早就到了,可惜中间摸鱼了太多天,最近要抓紧进度了
300题纪念

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
如何吸引顾客 怎样吸引顾客加入... 如何激活群的顾客活跃度,是商家在运营过程中绕不开的事情。当新用户来到商家的私域流量群时,商家一般会采...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
地铁怎么买票 乘坐地铁如何买票 目前,上海轨道交通全网络运营里程已增至831公里,线路增至20条,与此同时,轨道交通的支付方式也日益...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...