力扣876:链表的中间结点

给你单链表的头结点 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 ,返回第二个结点。

思想:先求链表长度,然后求链表的中间结点

代码:

复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
struct ListNode* middleNode(struct ListNode* head) {
    struct ListNode *p=head;
    int len=0;
    int n=0;
    while(p!=NULL){
        p=p->next;
        len++;
    }
    p=head;
    while(n<len/2){
        n++;
        p=p->next;
    }
    return p;
}

时间复杂度O(n);空间复杂度O(1)

相关推荐
剪一朵云爱着5 小时前
力扣81. 搜索旋转排序数组 II
算法·leetcode·职场和发展
报错小能手8 小时前
刷题日常 5 二叉树最大深度
算法
ᐇ9598 小时前
Java LinkedList集合全面解析:双向链表的艺术与实战
java·开发语言·链表
Greedy Alg9 小时前
LeetCode 84. 柱状图中最大的矩形(困难)
算法
im_AMBER9 小时前
Leetcode 52
笔记·学习·算法·leetcode
小欣加油9 小时前
leetcode 946 验证栈序列
c++·算法·leetcode·职场和发展
包饭厅咸鱼9 小时前
PaddleOCR----制作数据集,模型训练,验证 QT部署(未完成)
算法
无敌最俊朗@9 小时前
C++ 并发与同步速查笔记(整理版)
开发语言·c++·算法
王哈哈^_^9 小时前
【完整源码+数据集】课堂行为数据集,yolo课堂行为检测数据集 2090 张,学生课堂行为识别数据集,目标检测课堂行为识别系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计