删除链表的倒数第N个节点(java实现)

原文: 删除链表的倒数第N个节点(java实现)_aha_jasper的博客-CSDN博客_删除链表的倒数第n个节点java
https://blog.csdn.net/aha_jasper/article/details/112233642

detachment_w 2021-01-05 14:38:57 398 收藏 1
分类专栏: 数据结构和算法题 文章标签: 链表 java 数据结构 leetcode
版权

数据结构和算法题
专栏收录该内容
8 篇文章1 订阅
订阅专栏
转载自 LeetCode - 删除链表的倒数第N个节点,如果不太理解代码可以去这个博客看看链表-如何高效删除链表的倒数第N个节点

删除链表的倒数第N个节点(java实现)
题目
给定一个链表,删除链表的倒数第 n 个节点并返回头结点。

例如,给定一个链表: 1->2->3->4->5, 并且 n = 2. 当删除了倒数第二个节点后链表变成了 1->2->3->5.

说明:
给的 n 始终是有效的。尝试一次遍历实现。

解法
很简单的一道题,既然只允许遍历一次,且N一直有效,那么可以利用双指针解法(前指针、后指针),让前指针先走N步,再让两个在指针同时后移,直到前指针到达尾部,此时,后指针的下一个节点就是要被删除的节点了。

@Test
public void test() {
ListNode head = new ListNode(1);
ListNode listNode = removeNthFromEnd(head, 1);
System.out.println(listNode);
}
1
2
3
4
5
6
public ListNode removeNthFromEnd(ListNode head, int n) {
ListNode preNode = head;
ListNode curNode = head;

for (int i = 0; i < n; i++) {
curNode = curNode.next;
}

if (curNode == null) {
return preNode.next;
}

while (curNode.next != null) {
preNode = preNode.next;
curNode = curNode.next;
}

preNode.next = preNode.next.next;

return head;
}

class ListNode {
int val;
ListNode next;

ListNode(int x) {
val = x;
}
}
————————————————
版权声明:本文为CSDN博主「detachment_w」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/aha_jasper/article/details/112233642

posted @ 2021-12-25 13:10  ArielMeng  阅读(161)  评论(0编辑  收藏  举报