【LeetCode高频100题-2】冲冲冲
admin
2024-01-17 19:51:44
0

文章目录

  • 22. 括号生成
    • 题意
    • 解法1
  • 23. 合并K个升序链表
    • 题意
    • 解法1 暴力两两合并
    • ==解法2 直接获取k个节点中的最小节点(堆)==
  • 31. 下一个排列
    • 题意
    • 解法1 分析找规律

22. 括号生成

题意

解法1


23. 合并K个升序链表

题意

  • 合并k个升序的链表
  • 是“合并两个升序链表”的扩展版

解法1 暴力两两合并

转换题目,每次仅合并两个升序链表。

合并两个升序链表:

 ListNode* mergeTwoLists(ListNode* a,ListNode* b){if((!a)||(!b)) return a?a:b;ListNode head,*tail=&head,*aptr=a,*bptr=b;while(aptr&&bptr){if(aptr->valval){tail->next=aptr;aptr=aptr->next;}else{tail->next=bptr;bptr=bptr->next;}tail=tail->next;}tail->next=(aptr?aptr:bptr);return head.next;}

合并k个升序链表:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:
ListNode* mergeTwoLists(ListNode* a,ListNode* b)
{if((!a)||(!b)) return a?a:b;ListNode head;ListNode* aptr=a,*bptr=b,*tail=&head;while(aptr&&bptr){if(aptr->valval){tail->next=aptr;aptr=aptr->next;}else{tail->next=bptr;bptr=bptr->next;}tail=tail->next;}tail->next=(aptr?aptr:bptr);return head.next;
}ListNode* mergeKLists(vector& lists) {ListNode* ans=NULL;for(int i=0;i

解法2 直接获取k个节点中的最小节点(堆)

“合并两个升序链表”每次选择两个链表中最小的节点,那么类比到“合并k个升序链表”,可以每次选择k个链表中最小的节点,这个选择可以靠优先级队列(二叉堆) 来实现。

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:struct Status{int val;ListNode* ptr;bool operator < (const Status &rhs) const{return val > rhs.val;}};priority_queue q;ListNode* mergeKLists(vector& lists) {for(auto node:lists){if(node) q.push({node->val,node});}ListNode head,*tail=&head;while(!q.empty()){auto f=q.top();q.pop();   //取根tail->next=f.ptr;tail=tail->next;if(f.ptr->next) q.push({f.ptr->next->val,f.ptr->next});}return head.next;}
};

复杂度
优先队列q中元素最多有k个,每次poppush的复杂度为O(logk),由于所有链表的每一个节点都会pushpop一遍,所以算法的总复杂度为O(nlogk)


31. 下一个排列

题意

  • 相当于找下一个尽可能小的更大的数
  • 应当选择最靠右的最左边的较小数最靠右的尽可能小的数交换,所以选择从右向左遍历寻找目标数。
  • 最靠右的最左边的较小数:从右向左寻找第一个升序二元组 tar_i=i
  • 最靠右的尽可能小的数:从右往左第一个大于nums[tar_i]的数,记为tar_j

解法1 分析找规律

例如,452631,应当选择2与3交换。

也就是说,从右向左寻找第一个升序二元组 ,记录tar_i=i,需要注意的是,此时,i右边一定是一个降序排列。然后再寻找一个比nums[i]大却又尽可能小的数,由于i右边是一个降序排列,所以从右往左寻找第一个大于nums[tar_i]的数即可,记为tar_j。最后,将tar_i右边的数进行升序重排即可。

如果找不到这样一个升序二元组 ,说明此时的序列是一个降序序列,那么下一个排列就是这些数的升序排列,直接重新sort即可。

class Solution {
public:void nextPermutation(vector& nums) {//先不考虑重复数的存在int n=nums.size();int tar_i=-1,tar_j=-1;for(int i=n-2;i>=0;i--){if(nums[i]tar_i=i;break;}}if(tar_i==-1){sort(nums.begin(),nums.end());return ;}for(int i=n-1;i>tar_i;i--){if(nums[i]>nums[tar_i]){tar_j=i;break;}}swap(nums[tar_i],nums[tar_j]);sort(nums.begin()+tar_i+1,nums.end());return ;}
};

相关内容

热门资讯

西苑医院脾胃病科举办“胃爱守护... 近日,中国中医科学院西苑医院脾胃病科在门诊楼一层大厅举办 “胃爱守护・食刻舒心” 胃食管反流病专病义...
原创 “... “三伏不补,一年受苦”!三伏天是一年中最热、最潮湿的日子,人就像在 “桑拿房” 里待着,一动就出汗,...
贵州威宁举办避暑旅游季活动:“... 7月28日,2025年雪山灼甫“村歌”示范展示暨“我们的中国梦·文化进万家”贵州省威宁自治县避暑旅游...
水韵江苏 风雅德比|盐城VS常... 当盐渎新城的呦呦鹤鸣,应和着滩涂的潮汐,激荡起明代杨瑞云笔下“苍茫一气接乾坤,巨浪长风日夜喧”的壮阔...
带孩子去新疆游玩15天费用攻略... 带孩子去新疆怕预算超支又玩不尽兴?去年我带 7 岁女儿的十五天跟团游堪称 “完美范本”!网上找到的导...
共赴星河之约,枕星入眠!“恰西... 七月的巩留,云朵把影子投在起伏的恰西草原,牛羊像撒落的珍珠,雪岭云杉在天边排成长岗......这片 ...
让世界认识四川,剑门关国家5A... 爱旅游,爱生活。旅游可以放松自己的心情,宽阔自己的心境,你有好久没来一场说走就走的旅行,忘掉不顺心,...
受用的四川旅行五天方案,成都旅... 宝子们,四川,宛如一颗镶嵌在中国西南的璀璨明珠,散发着独特而迷人的魅力。它有着“天府之国”的美誉,这...
九公山公墓网红墓园:九公山名人... 当“特种兵旅游”的热潮退去,年轻人开始用脚步丈量历史的厚度。在九公山长城纪念林,一群特殊的“追星族”...
西北环线8日深度游,大西北经典... 西北环线8日深度游,大西北经典路线全攻略,这样走不踩雷! 想要一次看遍草原、沙漠、湖泊和丹霞的极致...
原创 全... 全球184国中唯一游客锐减的国家是哪里? 在新冠疫情后全球旅游地迎来V型复苏、各处景点人满为患的当...
安徽一地公布三起典型案例 近日 池州市第一批旅游行业导游乱象、 强制消费等问题行政处罚典型案例公布 详情如下 ↓↓↓ 为切实...
众信旅游重庆落地发布会圆满举办... 众信旅游 环球旅游好伙伴! 2025 众信旅游重庆落地发布会圆满举办 正式开启西南市场新篇章 近日...
深圳民宿老板太卷了!4天撒2吨... 封面新闻记者 罗田怡 杨金祝 7月末的深圳较场尾海滩,一场别开生面的“赶海”活动正在上演。与传统赶海...
西北游玩省心攻略,经典线路+省... 西北,这片广袤而神秘的土地,以其雄浑壮美的自然景观和深厚多元的文化底蕴,一直是我旅行清单上的终极梦想...
万达电影四家影城获IMAX卓越... 搜狐娱乐讯 7月29日,IMAX公司公布2024-2025年度IMAX卓越奖,万达电影旗下四家影城凭...
天河潭暑期烟花秀火花天夏攻略 天河潭暑期烟花秀火花天夏攻略 天河潭避暑旅游季活动火热开启,今年的暑期活动格外引人注目。从7月12...
北京门头沟区已累计转移1519...   新华社北京7月29日电(记者王艳刚)记者29日从北京市门头沟区获悉,截至29日08时,门头沟区累...