当前位置: 首页 > wzjs >正文

做视频网站了几百万网站整体框架

做视频网站了几百万,网站整体框架,きょこんきょうしゃ在线,个人主页网页设计源代码LeetCode-链表-合并两个有序链表 ✏️ 关于专栏:专栏用于记录 prepare for the coding test。 文章目录 LeetCode-链表-合并两个有序链表📝 合并两个有序链表🎯题目描述🔍 输入输出示例🧩题目提示🧪AC递归&…

image-20250520203051704

LeetCode-链表-合并两个有序链表

✏️ 关于专栏:专栏用于记录 prepare for the coding test


文章目录

  • LeetCode-链表-合并两个有序链表
    • 📝 合并两个有序链表
      • 🎯题目描述
      • 🔍 输入输出示例
      • 🧩题目提示
      • 🧪AC递归
      • 🧪AC迭代
    • 🌟 总结

📝 合并两个有序链表

🎯题目描述

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

🔗题目链接:合并两个有序链表

🔍 输入输出示例

示例 1:

img
输入:l1 = [1,2,4], l2 = [1,3,4]
输出:[1,1,2,3,4,4]

示例 2:

输入:l1 = [], l2 = []
输出:[]

示例 3:

输入:l1 = [], l2 = [0]
输出:[0]

🧩题目提示

  • 两个链表的节点数目范围是 [0, 50]
  • -100 <= Node.val <= 100
  • l1l2 均按 非递减顺序 排列

🧪AC递归

可以直接将 mergeTwoLists 用作递归函数来合并两个有序链表:

  • 递归终止条件:当其中一个链表为空时,说明不需要再继续合并,直接返回另一个非空链表即可,这个链表本身就是有序的。
  • 递归处理过程:当两个链表都不为空时,比较当前节点的值。若 list1 的当前节点值较小,则将 list1.nextlist2 继续递归合并,并将合并后的结果接在 list1 当前节点后面,返回 list1。反之,则将 list2.nextlist1 合并,并将结果接到 list2 后,最后返回 list2

这种方式通过递归自然地完成了节点的选择与链接,实现了有序合并。

/*** 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* list1, ListNode* list2) {if(list1 == nullptr) return list2;if(list2 == nullptr) return list1;if(list1->val < list2->val){list1->next = mergeTwoLists(list1->next,list2);return list1;}else{list2->next = mergeTwoLists(list1,list2->next);return list2;}}
};

🧪AC迭代

我们可以先创建一个哨兵节点,它位于最终合并链表的头节点之前。这样做的好处是能统一处理流程,不用单独处理头节点或考虑链表为空的特殊情况,整体逻辑更加清晰简洁。

接下来,遍历两个链表,比较当前节点的值。若 list1 当前节点的值较小,就将其接到新链表的尾部,并让 list1 向后移动一位;反之,则将 list2 的当前节点接上,并将 list2 向后推进。若两者值相同,我们可以统一选择将 list2 的节点链接到结果链表中。

这一过程会持续进行,直到 list1list2 中至少有一个遍历完毕。

当循环结束时,仍可能存在某个链表还有未处理完的节点。此时可以直接将剩下的部分追加到合并链表的末尾。

最终返回的是哨兵节点的 next 指针所指向的节点,也就是新链表的第一个有效节点。

/*** 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* list1, ListNode* list2) {ListNode dummy{};   //用哨兵节点简化代码逻辑auto cur = &dummy;  //cur指向新链表的末尾while(list1&&list2){if(list1->val < list2->val){cur->next = list1;list1 = list1->next;}else{cur->next = list2;list2 = list2->next;}cur = cur->next;}cur->next = list1 ? list1 : list2;return dummy.next;}
};

🌟 总结

合并两个有序链表可以通过递归迭代两种方式来实现,思路都围绕“逐步选择较小值节点”展开。

递归法

  • 思想简洁,利用函数调用栈自动维护合并过程。
  • 每次比较两个链表当前节点,选出较小值节点作为当前结果节点,继续递归合并剩余部分。
  • 递归终止条件是任一链表为空,直接返回另一个链表。

迭代法

  • 更加实用,避免了递归带来的额外栈空间开销。
  • 使用一个哨兵(dummy)节点作为新链表的起点,便于处理头节点和边界情况。
  • 通过 cur 指针逐步向后链接较小节点,最后再拼接剩余部分。

技巧亮点

  • 哨兵节点(dummy)是处理链表问题中常见且高效的技巧,避免处理头节点的特殊逻辑。
  • 两种方法都充分利用了“链表本身有序”的性质,无需新建节点,仅通过指针重新组织结构即可。

文章转载自:

http://A5pvdjzI.rxgnn.cn
http://FxlgqweW.rxgnn.cn
http://7xj6Ydnl.rxgnn.cn
http://YGTNa7LO.rxgnn.cn
http://7udTiaym.rxgnn.cn
http://Cph5HfW9.rxgnn.cn
http://0GeM6DK8.rxgnn.cn
http://3XBgWLsb.rxgnn.cn
http://lJ2tjMB8.rxgnn.cn
http://6IMsh32p.rxgnn.cn
http://Kdzajoyq.rxgnn.cn
http://EfQwgwBr.rxgnn.cn
http://gFP7H8lR.rxgnn.cn
http://CWY0pQCX.rxgnn.cn
http://bcQaCCUF.rxgnn.cn
http://DReBKu2P.rxgnn.cn
http://MkDZysD9.rxgnn.cn
http://R7SAxRmq.rxgnn.cn
http://9Zx0dZXV.rxgnn.cn
http://4ls068P5.rxgnn.cn
http://BSrZNHb2.rxgnn.cn
http://kUP5marA.rxgnn.cn
http://AR0feByw.rxgnn.cn
http://fbM9nhFl.rxgnn.cn
http://5bSA2W4i.rxgnn.cn
http://PnkHYBrd.rxgnn.cn
http://hSEunmVI.rxgnn.cn
http://29FlwKj4.rxgnn.cn
http://59P1nDln.rxgnn.cn
http://yB4xX5BW.rxgnn.cn
http://www.dtcms.com/wzjs/730010.html

相关文章:

  • 通化市建设局网站怎么接广告推广
  • 苏州高新区网站建设晋城市城乡建设局网站
  • 怎样做天猫网站视频深圳制作网站建设推广
  • 谷歌没收录网站主页 301重定向什么是指数基金
  • 紧固件做网站有效果吗网站域名 评估作价
  • 服装网站建设竞争对手调查分析广广东网站建设
  • 南和网站建设爱星光(istar)高端网站建设
  • 查公司的国家网站有哪些怀化网站优匿
  • 网站建设与运营的公司wordpress底部版权插件
  • 酒店网站建设范文为什么点不开网站
  • 鄂尔多斯市住房和城乡建设厅网站有没有做长图的网站
  • 深圳市潮流网络是不是外包站长工具的使用seo综合查询运营
  • 网站建设英语翻译wordpress 免费吗
  • 网站建设教程模板wordpress 新闻列表
  • 机构网站建设番禺软件公司
  • 珠海建设银行官方网站门头沟手机网站建设
  • 双鱼儿 网站建设北京网站开发工程师
  • cpa推广做网站音乐网站制作策划书
  • 济南网站建设就选搜点网络ok如何建设网站赚钱
  • 网站 网页区别网站 展示
  • 腾讯云网站搭建怎样申请网站呢
  • 白银市城市建设设计院网站一家做公司点评网站
  • 泰塔科技网站建设网站首页模板下载
  • 怎样做淘宝网站中秋节ppt免费模板下载
  • 济南市住建厅官方网站wordpress 扫码付款
  • 邢台开发区网站青白江做网站的公司
  • 广州外贸网站建设曲靖今天最新通知
  • 北京中燕建设公司网站网络品牌推广策略
  • -邵阳网络公司-邵阳网站建设|邵阳网站制作什么是网站链接优化
  • 做网站都有什么功能手机网站关键词排名