首页
学习
活动
专区
圈层
工具
发布

[leetcode链表系列] 1 链表的中间节点

1 Leetcode876 链表的中间节点

给定一个带有头结点 head 的非空单链表,返回链表的中间结点。

如果有两个中间结点,则返回第二个中间结点。

输入:[1,2,3,4,5]

输出:此列表中的结点 3 (序列化形式:[3,4,5])

返回的结点值为 3 。 (测评系统对该结点序列化表述是 [3,4,5])。

注意,我们返回了一个 ListNode 类型的对象 ans,这样:

ans.val = 3, ans.next.val = 4, ans.next.next.val = 5, 以及 ans.next.next.next = NULL.

示例2:

输入:[1,2,3,4,5,6]

输出:此列表中的结点 4 (序列化形式:[4,5,6])

由于该列表有两个中间结点,值分别为 3 和 4,我们返回第二个结点。

小蓝希望大家在此思考1分钟,

效果更好哈!

01 题目解析

  • 链表简述
    • 说到链表,难免会想到数组,数组的内存地址空间连续,查找速度快(O(1)),但是插入和删除会因为大量移动元素导致效率不高,所以引入了链表结构。
    • 链表中内存低地址不连续,通过"指针"将零散的地址链接在一起,如下图(单链表)所示。
  • 解题思路(快慢指针)
    • 题中需要返回中间节点,我们使用两个指针p,q,p指针一次往前走两步,q指针一次走一步,当快指针p到达末尾也就是NULL的时候,p所指向的就是中间节点。我们看一下动画!

02 代码实现

1 c++版本

2 python版本

3 java版本

下一篇
举报
领券