news 2026/5/23 6:45:43

如何在链表中使用双指针技术

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何在链表中使用双指针技术

题目:给定一个链表,删除倒数第n个结点。如 1->2->3->4->5->null,n=2,返回 1->2->3->5->null。

需要明确的地方:n从0计还是从1计?n不合法,负数或者大于连标长度如何处理(保证n合法)。

思路1:先遍历一遍计算链表长度,再遍历一遍删除第length-n+1个结点。

思路2:能不能只遍历一遍链表就解决问题呢?首先添加一个虚拟结点,找到要删除结点的前驱。使用双指针,也就是快慢指针。

公用代码:

​ public class ListNode { public int val; public ListNode next; public ListNode(int x) { this.val = x; this.next = null; } public static ListNode createList(int[] nums) { if(null == nums || 0 == nums.length) return null; ListNode head = new ListNode(nums[0]); ListNode needle = head; for(int i = 1; i < nums.length;++i) { ListNode node = new ListNode(nums[i]); needle.next = node; needle = needle.next; needle.next = null; } return head; } }
public ListNode removeNthFromEnd(ListNode head, int n) { if (n < 0) return null; // 创建虚拟头指针 ListNode dummyHead = new ListNode(-1); dummyHead.next = head; ListNode pre = dummyHead; ListNode fast = dummyHead.next; // 快指针先走n步 for (int i = 0; i < n; i++) { if (fast != null) fast = fast.next; } // 快慢指针一同前行,但是这里要对快指针进行判断哦 while (fast != null) { pre = pre.next; fast = fast.next; } // 此时fast指向null,而pre就指向要删除结点的前驱 ListNode delNode = pre.next; pre.next = delNode.next; return dummyHead.next; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 9:37:25

征程 6P/H 计算平台部署指南

1.前言 本文旨在提供 征程 6H/P 计算平台的部署指南&#xff0c;将会从硬件、软件两部分进行介绍&#xff0c;本文整理了我们推荐的使用流程&#xff0c;和大家可能会用到的一些工具特性&#xff0c;以便于您更好地理解工具链。某个工具具体详 l 细的使用说明&#xff0c;还请…

作者头像 李华
网站建设 2026/5/18 23:40:20

F5-TTS语音合成模型:从零开始掌握配置与自定义加载

F5-TTS语音合成模型&#xff1a;从零开始掌握配置与自定义加载 【免费下载链接】F5-TTS Official code for "F5-TTS: A Fairytaler that Fakes Fluent and Faithful Speech with Flow Matching" 项目地址: https://gitcode.com/gh_mirrors/f5/F5-TTS F5-TTS作…

作者头像 李华
网站建设 2026/5/21 13:08:22

【架构演进与选型分析 】

单体架构 电商初期采用单体架构&#xff0c;所有功能集中在一个应用内&#xff0c;代码分层明确&#xff08;表示层、业务层、数据访问层、DB层&#xff09;。适合业务简单、团队规模小的场景&#xff0c;但模块依赖模糊&#xff0c;多团队开发易冲突。例如早期淘宝和eBay因代码…

作者头像 李华
网站建设 2026/5/22 18:44:25

【WRF理论第二十期】湍流与扩散(Turbulence / Diffusion)

目录 湍流与扩散(Turbulence / Diffusion) 概念解释 数学表达式解析 扩散选项 diff_opt 的控制参数说明 km_opt 参数详解:湍流扩散系数计算方法 sfs_opt 参数详解:亚网格尺度(SGS)应力模型 六阶扩散参数 diff_6th_opt:六阶水平扩散选项 `diff_6th_factor`:六阶扩散强度…

作者头像 李华
网站建设 2026/5/22 9:05:43

挖漏洞一个月赚2万多,别被骗了!

有人说挖漏洞比上班挣的还多&#xff0c;也有人说靠挖漏洞赚钱得饿死&#xff0c;2025年挖漏洞到底还能不能行&#xff1f;新手如果想挖漏洞又该怎么上手&#xff1f;一篇文章告诉你。 首先先说2025年挖漏洞的前景如何&#xff1f; 众所周知挖漏洞的白帽子是越来越多了&#x…

作者头像 李华
网站建设 2026/5/18 17:18:45

Linux的权限

1. 怎么看权限&#xff1f; (ls -l)在终端输入 ls -l&#xff0c;你会看到类似下面的一行“天书”&#xff1a;Bashdrwxr-xr-x 2 user dev 4096 Dec 12 10:00 project/我们需要关注的是最前面的 10 个字符 drwxr-xr-x&#xff0c;它分为 4 个部分解读&#xff1a;字符位置…

作者头像 李华