链表的中间结点数据结构oj题(力扣876)

目录

题目描述:

题目分析:

代码解决:


题目描述:

给你单链表的头结点 head ,请你找出并返回链表的中间结点。如果有两个中间结点,则返回第二个中间结点。

题目分析:

寻找中间节点这道题原理就是通过1/2总长度,对于我来说一开始想到的方法一 就是先计算内部有多少个节点,然后进行除以二,得到中间节点数后,进行遍历到对应的中间节点(本人有点笨,只能想到这种方法了)。通过向大佬学习,我发现一个更加好用的方法,思路二 就是快慢指针,这个快慢指针就是一个fast指针每次走两步,另一个low指针每次走一步,等fast出界时,low就是中间指针,这个方法是个好方法思路简单,代码也好写,就是难想出来哈哈哈。

代码解决:

思路一:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
typedef struct ListNode ListNode;
struct ListNode* middleNode(struct ListNode* head) {
    ListNode* n1, * n2;
    n1 = n2 = head;
    int count = 0;
    //遍历计算链表长度
    while (n1)
    {
        n1 = n1->next;
        count++;
    }
    //移动到中间链表
   count = count / 2;
   while (count)
   {
       n2 = n2->next;
       count--;
   }
    return n2;
}

思路二:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
typedef struct ListNode ListNode;
struct ListNode* middleNode(struct ListNode* head) {
    ListNode* fast = head;
    ListNode* low = head;
    while (fast != NULL && fast->next != NULL)
    {
        fast = fast->next->next;
        low = low->next;
    }
    return low;
}
相关推荐
稚辉君.MCA_P8_Java19 小时前
Gemini永久会员 Java实现的暴力递归版本
java·数据结构·算法
leoufung20 小时前
逆波兰表达式 LeetCode 题解及相关思路笔记
linux·笔记·leetcode
星释21 小时前
Rust 练习册 67:自定义集合与数据结构实现
数据结构·算法·rust
Aspect of twilight1 天前
LeetCode华为大模型岗刷题
python·leetcode·华为·力扣·算法题
2301_807997381 天前
代码随想录-day47
数据结构·c++·算法·leetcode
Elias不吃糖1 天前
LeetCode每日一练(3)
c++·算法·leetcode
别动哪条鱼1 天前
FFmpeg 核心数据结构关系图
数据结构·ffmpeg
小龙报1 天前
《算法通关指南数据结构和算法篇(2)--- 链表专题》
c语言·数据结构·c++·算法·链表·学习方法·visual studio
万物挽挽1 天前
数据结构概述
数据结构
wangwangmoon_light1 天前
1.10 数据结构之图
数据结构