链表的中间节点

这题需要用到快慢指针的思想,快指针叫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
}
相关推荐
飞Link42 分钟前
大模型长文本的“救命稻草”:深度解析 TurboQuant 与 KV Cache 压缩技术
算法
郝学胜-神的一滴1 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Je1lyfish2 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午2 小时前
03-二叉树——从递归遍历到非递归实现
java·算法
Brilliantwxx2 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法
NorburyL4 小时前
DPO笔记
深度学习·算法
老纪的技术唠嗑局4 小时前
深度解析 LLM Wiki / Obsidian-Wiki / GBrain:Agent 时代知识的“自组织”与“自进化”
大数据·数据库·人工智能·算法
YXXY3137 小时前
模拟算法的介绍
算法
happymaker06267 小时前
简单LRU的实现(基于LinkedHashMap)
算法·leetcode·lru
会编程的土豆8 小时前
【数据结构与算法】空间复杂度从入门到面试:不仅会算,还要会解释
数据结构·c++·算法·面试·职场和发展