news 2026/6/10 16:02:57

链表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/6/10 17:41:55

「当学术写作遇上认知脚手架」:Paperzz 如何用AI重构毕业论文的“生成逻辑”——一位理工科研究生的72小时实验手记与非功利性观察

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 paperzz - 毕业论文-AIGC论文检测-AI智能降重-ai智能写作https://www.paperzz.cc/dissertation 副标题&#xff1a;它未曾替我写出一个字&#xff0c;却让我第一次看清了论文本应生长的样子 0. 前奏&#…

作者头像 李华
网站建设 2026/6/10 17:40:58

MyBatis-Plus与Spring Boot 3.x版本兼容性深度解析与实战指南

在Java开发领域&#xff0c;Spring Boot与MyBatis-Plus的组合已成为企业级应用开发的主流技术栈。然而&#xff0c;随着Spring Boot 3.x版本的发布&#xff0c;许多开发者在升级过程中遇到了令人困惑的兼容性问题。本文将从实际问题出发&#xff0c;深入剖析版本冲突的本质&…

作者头像 李华
网站建设 2026/6/10 12:26:27

谷歌 sg-ss 分析

声明: 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01; 部分python代码 with open(google3.j…

作者头像 李华
网站建设 2026/6/10 0:00:54

毕业设计 基于深度学习的水果识别

文章目录1 前言2 开发简介3 识别原理3.1 传统图像识别原理3.2 深度学习水果识别4 数据集5 部分关键代码5.1 处理训练集的数据结构5.2 模型网络结构5.3 训练模型6 识别效果1 前言 &#x1f525;这两年开始毕业设计和毕业答辩的要求和难度不断提升&#xff0c;传统的毕设题目缺少…

作者头像 李华
网站建设 2026/6/10 13:50:39

DBLens:开启数据库管理新纪元——永久免费,智能高效的国产化开发利器

在数字化转型加速推进的当下&#xff0c;数据库管理作为企业 IT 架构的核心环节&#xff0c;其效率与安全性直接影响业务迭代速度与数据资产价值。深圳市源创星域网络科技有限公司重磅推出的国产可视化数据库管理软件 ——DBLens for MySQL&#xff0c;凭借 AI 原生技术与人性化…

作者头像 李华
网站建设 2026/6/10 9:12:47

AgentBench快速上手:从零开始的智能体评测完全指南

AgentBench快速上手&#xff1a;从零开始的智能体评测完全指南 【免费下载链接】AgentBench A Comprehensive Benchmark to Evaluate LLMs as Agents (ICLR24) 项目地址: https://gitcode.com/gh_mirrors/ag/AgentBench 项目概述 AgentBench是由THUDM开发的一个综合性评…

作者头像 李华