news 2025/12/27 13:54:50

链表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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/23 23:43:29

Patroni高可用性架构深度解析:从核心原理到生产实践

Patroni高可用性架构深度解析&#xff1a;从核心原理到生产实践 【免费下载链接】patroni A template for PostgreSQL High Availability with Etcd, Consul, ZooKeeper, or Kubernetes 项目地址: https://gitcode.com/gh_mirrors/pat/patroni Patroni作为PostgreSQL高可…

作者头像 李华
网站建设 2025/12/23 18:27:14

StickerBaker:基于Elixir与Phoenix的AI贴纸生成架构解析

StickerBaker&#xff1a;基于Elixir与Phoenix的AI贴纸生成架构解析 【免费下载链接】stickerbaker 项目地址: https://gitcode.com/GitHub_Trending/st/stickerbaker 技术架构价值定位 StickerBaker代表了现代Web应用开发的前沿实践&#xff0c;通过Elixir语言的并发…

作者头像 李华
网站建设 2025/12/23 22:35:21

毕业设计 深度学习yolov11痤疮检测医疗辅助系统(源码+论文)

文章目录0 前言1 项目运行效果2 课题背景2.1、痤疮的医学背景与社会影响2.2、传统痤疮诊断方法的技术局限2.2.1 视觉评估法2.2.2 摄影记录法2.2.3 皮肤镜检测2.3、计算机视觉在皮肤病诊断中的发展3.1 早期图像处理方法(2000-2010)2.3.2 机器学习时代(2011-2015)2.4、深度学习带…

作者头像 李华
网站建设 2025/12/26 21:12:16

AppSync Unified:iOS设备应用签名验证的终极解决方案

AppSync Unified&#xff1a;iOS设备应用签名验证的终极解决方案 【免费下载链接】AppSync Unified AppSync dynamic library for iOS 5 and above. 项目地址: https://gitcode.com/gh_mirrors/ap/AppSync 想要在越狱的iOS设备上自由安装任意IPA应用包吗&#xff1f;App…

作者头像 李华
网站建设 2025/12/23 8:49:30

大麦APP抢票技术分享

大麦APP抢票技术探讨重要提醒&#xff1a;本文仅供学习交流&#xff0c;请勿用于任何非法目的&#xff0c;严禁商业化利用或参与黄牛活动&#xff01;一、背景与动机 每逢热门演唱会或大型体育赛事开售&#xff0c;大麦APP上的门票几乎"秒空"。普通用户眼睁睁看着刷新…

作者头像 李华
网站建设 2025/12/23 20:24:41

C语言编程练习(二)

常见的C语言编程练习类型包括基础语法应用、数组操作、循环控制和算法实现。1、输入一个年份&#xff0c;判断该年是否为闰年&#xff0c;若为闰年则输出“yes”&#xff0c;否则输出“no”。2、从键盘输入3个数&#xff0c;将其从小到大排序后输出

作者头像 李华