一、题目描述
给你单链表的头结点 head
,请你找出并返回链表的中间结点。
如果有两个中间结点,则返回第二个中间结点。
示例 1:
输入:head = [1,2,3,4,5] 输出:[3,4,5] 解释:链表只有一个中间结点,值为 3 。
示例 2:
输入:head = [1,2,3,4,5,6] 输出:[4,5,6] 解释:该链表有两个中间结点,值分别为 3 和 4 ,返回第二个结点。
提示:
- 链表的结点数范围是
[1, 100]
1 <= Node.val <= 100
二、思路分析
这道题有多种解决方案,可以选择先遍历一遍链表,得到链表的长度,然后在移动到中间的节点返回结果。这里我选择的方案是,使用快慢指针的方式,即创建两个指针,slowNode 慢指针和 fastNode 快指针,慢指针每次向后移动一位,快指针每次向后移动两位,则快指针的移动距离是慢指针的两倍,则当快指针到达链表的最后一个节点时,慢指针正好在中间的节点。
三、代码参考
1、Java
class Solution {
public ListNode middleNode(ListNode head) {
// 创建两个指针,分别为快慢指针,初始时都指向头节点,
ListNode slowNode = head;
ListNode fastNode = head;
// 循环结束条件,快指针 fastNode 走到链表的最后一个节点
while(fastNode != null && fastNode.next != null){
// 慢指针每次向后移动一下
slowNode = slowNode.next;
// 快指针每次向后移动两下
fastNode = fastNode.next.next;
}
// 返回结果
return slowNode;
}
}
2、Python
class Solution(object):
def middleNode(self, head):
# 创建两个指针,分别为快慢指针,初始时都指向头节点,
slowNode = head
fastNode = head
# 循环结束条件,快指针 fastNode 走到链表的最后一个节点
while fastNode and fastNode.next:
# 慢指针每次向后移动一下
slowNode = slowNode.next
# 快指针每次向后移动两下
fastNode = fastNode.next.next
# 返回结果
return slowNode