链表的中间节点

这题需要用到快慢指针的思想,快指针叫fast,慢指针是slow,快指针每次往后移两个节点,slow只移动一个节点,这样子fast的速度是slow的两遍,当fast遍历完链表,slow才遍历一半,正好就在中间。

代码:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
 typedef struct ListNode LSTNode;
struct ListNode* middleNode(struct ListNode* head) {
    LSTNode* slow,*fast;//定义两个指针
    fast=slow=head;//初始化指针
    while(fast&&fast->next)//fast走的快,它不能为空,并且它的next也不行
    {
        slow=slow->next;//slow每次往后移动一个节点
        fast=fast->next->next;//fast每次往后移动两个节点
    }
    return slow;//返回slow
}
相关推荐
liuzhangfeiabc15 分钟前
[luogu12542] [APIO2025] 排列游戏 - 交互 - 博弈 - 分类讨论 - 构造
c++·算法·题解
晴空闲雲34 分钟前
数据结构与算法-线性表-循环链表(Circular Linked List)
数据结构·算法·链表
一梦浮华37 分钟前
自学嵌入式 day21 - 数据结构 双向链表
数据结构·链表
比奇堡在逃帅哥38 分钟前
数据结构-DAY05
数据结构
四谷夕雨1 小时前
C++数据结构——红黑树
开发语言·数据结构·c++
Jolen_xie1 小时前
Pytorch分布式训练,数据并行,单机多卡,多机多卡
人工智能·算法
珹洺1 小时前
C++从入门到实战(十六)String(中)String的常用接口(构造接口,析构接口,迭代器,遍历修改,容量管理与数据访问)
开发语言·c++·算法·stl
是店小二呀2 小时前
【优选算法 | 栈】深入栈模拟题:从题型特征到实现技巧
c++·算法
Tiny番茄2 小时前
LeetCode 93.复原IP地址 LeetCode 78.子集 LeetCode 90.子集II
算法·leetcode·职场和发展
SylviaW082 小时前
python-leetcode 69.最小栈
数据结构·算法·leetcode