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 10:34:23

SonarQube界面定制完全指南:从品牌标识到深度个性化

SonarQube界面定制完全指南&#xff1a;从品牌标识到深度个性化 【免费下载链接】sonarqube Continuous Inspection 项目地址: https://gitcode.com/gh_mirrors/so/sonarqube SonarQube作为业界领先的持续代码质量检测平台&#xff0c;不仅提供了强大的代码分析能力&…

作者头像 李华
网站建设 2026/4/11 10:39:10

61、Tectia for Windows:功能与配置全解析

Tectia for Windows:功能与配置全解析 1. 客户端断开连接 当最后一个会话终止时,客户端会自动断开连接。若因某些原因需要手动断开连接,可使用“断开连接”工具栏图标或“文件/断开连接”菜单项。 2. 密钥管理 要管理用于公钥认证的密钥对,可通过“设置”工具栏图标或“…

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

52、Python 网络数据处理与编码实用指南

Python 网络数据处理与编码实用指南 1. hashlib 模块 1.1 功能概述 hashlib 模块实现了多种安全哈希和消息摘要算法,如 MD5 和 SHA1。要计算哈希值,可调用以下函数,函数名与所代表的算法名称相同。 1.2 哈希函数 函数 描述 md5() MD5 哈希(128 位) sha1() SHA1 …

作者头像 李华
网站建设 2026/4/16 13:30:41

32、模型/视图编程与数据库操作:自定义委托与数据库访问

模型/视图编程与数据库操作:自定义委托与数据库访问 1. 自定义委托概述 在数据展示和编辑中,若要对数据项的呈现和编辑进行完全控制,就需要创建自定义委托。委托可单纯用于控制外观(如只读视图),或通过提供自定义编辑器来控制编辑,也可两者兼顾。 2. 自定义委托的使用…

作者头像 李华