LeetCode 剑指 Offer 22. 链表中倒数第k个节点

题目描述

剑指 Offer 22. 链表中倒数第k个节点

image-20250507192744021

image-20241107205244010

思路分析

快慢指针问题

参考代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
func getKthFromEnd(head *ListNode, k int) *ListNode {
	fast, slow := head, head

	// 让 fast 指针先走 k 步
	for i := 0; i < k; i++ {
		fast = fast.Next
	}

	// 让 fast 和 slow 指针同时移动
	for fast != nil {
		fast = fast.Next
		slow = slow.Next
	}

	return slow
}
1
2
3
4
5
6
7
8
9
10
11
func trainingPlan(head *ListNode, k int) *ListNode {
	slow, fast := head, head
	for i := 0; i < k; i++ {
		fast = fast.Next
	}
	for fast != nil {
		fast = fast.Next
		slow = slow.Next
	}
	return slow
}

➡️ 点击查看 Java 题解

1
write your code here

相似题目

image-20250507192331822

本文作者:
本文链接: https://hgnulb.github.io/blog/2025/72487765
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处!