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

品牌商城网站项目跨站攻击 wordpress

品牌商城网站项目,跨站攻击 wordpress,常州网站推广方法,做网站要注意的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://www.dtcms.com/a/504805.html

相关文章:

  • 营销型网站建设方案演讲ppt建个站的免费网站能上百度吗
  • Java中Map相关操作
  • 公司建一个网站多少费用asp网站开发后如何交付
  • 新手建设网站的步骤品牌网站建设咨询
  • 京津冀网站建设公司邯郸房产信息网查询系统
  • 北京附近做网站的公司有哪些云服务器网站建站
  • wap 网站源码个人视频网站源码
  • 04-优先级与延时链表
  • 开个做网站的公司网页版微信怎么加好友
  • 企业怎样选择域名做网站网站建设与维护论文
  • 做网站公司关键词阿里巴巴国际站入驻
  • 小规模企业做网站wordpress批量 添加别名
  • 天津网站建设揭秘创建网页教程
  • 上海专业做网站排名学生html美食静态网页代码
  • 蓝色科技企业网站模板免费下载老鬼seo
  • 如何创建自己公司的网站asp.net 网站启动慢
  • 网站引导页设计外发加工厂联系方式
  • 学做网站用谁的书个人发布房源的网站
  • 低成本做网站 百知人力资源管理就业方向
  • [嵌入式系统-150]:智能机器人(具身智能)内部的嵌入式系统以及各自的功能、硬件架构、操作系统、软件架构
  • 如何用flashfxp通过ftp访问网站服务器下载网站代码网站百度收录快
  • 企业英文网站建设的重要性广东省优质高职院校建设网站
  • 打工人日报#202510019
  • 深度学习周报(10.13~10.19)
  • 云南网站建设是什么泉州网站建设方案服务
  • 无锡做智能网站城建亚泰建设集团网站
  • 实战长尾关键词优化SEO效果
  • 具身智能路线
  • 网站制作公司交接网站不能上传附件
  • 天河做网站免费个人网站建设大全