news 2026/6/23 18:48:29

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

作者头像

张小明

前端开发工程师

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/6/22 16:57:43

Golang实战:构建综合多头(逾期+反欺诈)风险查询的高性能客户端

一、用 Go 构建毫秒级风控“熔断器” 在实时信贷审批场景中&#xff0c;风控系统需要在极短的时间内&#xff08;通常 < 200ms&#xff09;做出决策。如果一个申请人当前存在信贷逾期或属于欺诈团伙成员&#xff0c;系统必须立即“熔断”流程&#xff0c;直接拒单&#xff0…

作者头像 李华
网站建设 2026/6/22 19:16:19

【TSP问题】基于蜣螂算法DBO和改进的蜣螂算法FADBO求解旅行商TSP问题(可根据自己的经纬度设置自己想要到达的地区)附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f34a;个人信条&#xff1a;格物致知,完整Matlab代码获取及仿真…

作者头像 李华
网站建设 2026/6/23 2:36:12

数据结构:二叉排序树,平衡二叉树,红黑树的介绍

一.二叉排序树二叉排序树的定义是任意一个父节点的值&#xff0c;大于其左子树节点的值&#xff0c;小于其右子树节点的值。以下是两个例子&#xff1a;&#xff08;1&#xff09;数组&#xff1a;5,3,1,4,8,9,7它的二叉排序树是这样的&#xff1a;它的时间复杂度是O(logn)。&a…

作者头像 李华
网站建设 2026/6/23 7:50:15

软件复用的分类与实现

复用的分类 复用的形式可以分为技术复用和业务复用两大类。技术复用包括代码复用和技术组件复用&#xff1b;业务复用包括业务实体复用、业务流程复用和产品复用。从复用的程度来看&#xff0c;从高到低依次划分为产品复用、业务流程复用、业务实体复用、组件复用、代码复用。 …

作者头像 李华