news 2026/4/16 0:44:45

链表part02

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
链表part02

链表的题目,如果涉及到对头节点的改动的话,就必须要用个哨兵节点dummy来执行头节点,不然不好多头节点进行移除或者换位的操作。
两两交换链表中的节点

/** * Definition for singly-linked list. * type ListNode struct { * Val int * Next *ListNode * } */funcswapPairs(head*ListNode)*ListNode{dummy:=&ListNode{Next:head}pre:=dummyforhead!=nil&&head.Next!=nil{// 第一步由dummy位置指向2pre.Next=head.Next// 存储位置3nxt:=head.Next.Next// 第二步由位置2指向位置1head.Next.Next=head// 第三步由位置1指向位置3head.Next=nxt pre=head head=head.Next}returndummy.Next}

删除链表的倒数第N个节点
可以用双指针来做这道题,注意这里的位置问题,首先快指针,因为要从dummy开始走起,所以它要走n+1步,所以第一次循环更新fast的位置时,要让它从0遍历到n,这样待会slow和fast一起走的时候,当fast走到nil时,slow刚好走到倒数第n个数的前一个位置。

/** * Definition for singly-linked list. * type ListNode struct { * Val int * Next *ListNode * } */funcremoveNthFromEnd(head*ListNode,nint)*ListNode{dummy:=&ListNode{Next:head}// 采用双指针slow,fast:=dummy,dummyfori:=0;i<=n;i++{// 注意i要 <= n,因为是从dummy开始走的// 所以要走n步slow待会才能走到删除节点的前一个位置fast=fast.Next}forfast!=nil{fast=fast.Next slow=slow.Next}slow.Next=slow.Next.Nextreturndummy.Next}

链表相交的位置
这道题可以一起遍历两条链表,如果两条链表的长度不一的话,可以把两条链表连起来遍历,比如说用 l1,l2分别指向两条链表headA,headB,当l1把headA遍历完之后,再指向headB继续遍历,当l2把headB遍历完之后,再指向headA继续遍历,这样最多O(2n)就能够找到相交的节点。

/** * Definition for singly-linked list. * type ListNode struct { * Val int * Next *ListNode * } */funcgetIntersectionNode(headA,headB*ListNode)*ListNode{l1,l2:=headA,headBforl1!=l2{ifl1!=nil{l1=l1.Next}else{l1=headB}ifl2!=nil{l2=l2.Next}else{l2=headA}}returnl1}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 0:43:21

当毕业论文遇上「学术元宇宙」:PaperZZ领衔的8大AI论文写作工具全景图鉴——一场从“被动代笔”到“主动科研伙伴”的范式迁移实验

这不是一篇工具测评&#xff0c;而是一份“学术生产力演化观察报告”。 2025年12月&#xff0c;我在CSDN后台收到一条留言&#xff1a;“老师&#xff0c;我用PaperZZ写了初稿&#xff0c;但导师说‘AI痕迹太重’&#xff0c;怎么改才像人写的&#xff1f;” 这句话像一颗石子…

作者头像 李华
网站建设 2026/4/15 2:18:09

终极指南:MASt3R与DUSt3R在5大关键场景下的技术决策

终极指南&#xff1a;MASt3R与DUSt3R在5大关键场景下的技术决策 【免费下载链接】mast3r Grounding Image Matching in 3D with MASt3R 项目地址: https://gitcode.com/GitHub_Trending/ma/mast3r 面对日益复杂的3D重建需求&#xff0c;技术决策者常常陷入选择困境&…

作者头像 李华
网站建设 2026/4/10 12:33:31

DBeaver SQL编辑器代码模板变量循环功能实战指南

DBeaver SQL编辑器代码模板变量循环功能实战指南 【免费下载链接】dbeaver 项目地址: https://gitcode.com/gh_mirrors/dbe/dbeaver 你是否曾经在编写大量相似SQL语句时感到疲惫不堪&#xff1f;每次都要手动修改表名、列名&#xff0c;重复着相同的操作模式&#xff1…

作者头像 李华
网站建设 2026/4/16 0:15:16

缓存策略深度解析:架构师必备的选型指南

在系统架构设计中&#xff0c;缓存选型是决定应用性能表现的关键技术决策。面对复杂多变的业务场景&#xff0c;架构师需要根据数据访问模式、一致性要求和系统负载特征&#xff0c;制定精准的缓存策略方案。 【免费下载链接】system-design-101 使用视觉和简单的术语解释复杂系…

作者头像 李华
网站建设 2026/4/15 17:22:46

xiaogpt兼容性全攻略:解决小米AI音箱连接失败的终极方案

xiaogpt兼容性全攻略&#xff1a;解决小米AI音箱连接失败的终极方案 【免费下载链接】xiaogpt Play ChatGPT and other LLM with Xiaomi AI Speaker 项目地址: https://gitcode.com/gh_mirrors/xia/xiaogpt 你的小爱音箱是否也遇到过这样的情况&#xff1a;明明配置好了…

作者头像 李华