题目
给定一个链表,删除链表的倒数第 n 个节点并返回头结点。
例如,
给定一个链表: 1->2->3->4->5, 并且 n = 2.
当删除了倒数第二个节点后链表变成了 1->2->3->5.
- 1
- 2
- 3
说明:
给的 n 始终是有效的。
尝试一次遍历实现。
解法
很简单的一道题,既然只允许遍历一次,且N一直有效,那么可以利用双指针解法(前指针、后指针),让前指针先走N步,再让两个在指针同时后移,直到前指针到达尾部,此时,后指针的下一个节点就是要被删除的节点了。
@Test
public void test() {
ListNode head = new ListNode(1);
ListNode listNode = removeNthFromEnd(head, 1);
System.out.println(listNode);
}
public ListNode removeNthFromEnd(ListNode head, int n) {
ListNode preNode = head;
ListNode curNode = head;
<span class="hljs-keyword">for</span> (<span class="hljs-built_in">int</span> i = <span class="hljs-number">0</span>; i < n; i++) {
curNode = curNode.<span class="hljs-keyword">next</span>;
}
<span class="hljs-keyword">if</span> (curNode == <span class="hljs-literal">null</span>) {
return preNode.<span class="hljs-keyword">next</span>;
}
<span class="hljs-keyword">while</span> (curNode.<span class="hljs-keyword">next</span> != <span class="hljs-literal">null</span>) {
preNode = preNode.<span class="hljs-keyword">next</span>;
curNode = curNode.<span class="hljs-keyword">next</span>;
}
preNode.<span class="hljs-keyword">next</span> = preNode.<span class="hljs-keyword">next</span>.<span class="hljs-keyword">next</span>;
return head;
}
class ListNode {
int val;
ListNode next;
ListNode(<span class="hljs-built_in">int</span> x) {
val = x;
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39