博客
关于我
Leetcode 876. 链表的中间结点
阅读量:227 次
发布时间:2019-03-01

本文共 772 字,大约阅读时间需要 2 分钟。

为了解决这个问题,我们需要找到给定单链表的中间结点。如果链表的长度为奇数,返回中间的那个结点;如果长度为偶数,返回第二个中间结点。

方法思路

  • 计算链表长度:首先,我们需要遍历整个链表,计算链表的长度。
  • 确定中间位置:根据链表的长度,确定中间结点的位置。如果链表长度为奇数,中间结点是第 (length + 1) / 2 个节点;如果是偶数,中间结点是第 length / 2 个节点。
  • 移动到中间节点:从链表的头节点开始,按照确定的中间位置移动,返回该节点。
  • 解决代码

    class Solution {public:    ListNode* middleNode(ListNode* head) {        int num = 0;        ListNode* current = head;        while (current != nullptr) {            num++;            current = current->next;        }        int k = num / 2;        current = head;        for (int i = 0; i < k; i++) {            current = current->next;        }        return current;    }};

    代码解释

  • 计算链表长度:使用 while 循环遍历链表,计算节点的总数 num
  • 确定中间位置:通过 num / 2 计算出要移动的步数 k
  • 移动到中间节点:从头节点开始,按照 k 步移动,返回中间节点。
  • 这种方法通过两次遍历链表,第一次计算长度,第二次移动到中间节点,时间复杂度为 O(n),其中 n 是链表的长度。

    转载地址:http://rhhv.baihongyu.com/

    你可能感兴趣的文章
    one_day_one--mkdir
    查看>>
    OpenCV 中的图像转换
    查看>>
    opencv5-图像混合
    查看>>
    opencv9-膨胀和腐蚀
    查看>>
    OpenCV与AI深度学习 | YOLO11介绍及五大任务推理演示(目标检测,图像分割,图像分类,姿态检测,带方向目标检测)
    查看>>
    OpenCV与AI深度学习 | 使用Python和OpenCV实现火焰检测(附源码)
    查看>>
    OpenCV与AI深度学习 | 使用YOLO11实现区域内目标跟踪
    查看>>
    OpenCV与AI深度学习 | 使用YOLOv8做目标检测、实例分割和图像分类(包含实例操作代码)
    查看>>
    OpenCV与AI深度学习 | 基于PyTorch实现Faster RCNN目标检测
    查看>>
    OpenCV与AI深度学习 | 基于PyTorch语义分割实现洪水识别(数据集 + 源码)
    查看>>
    OpenCV与AI深度学习 | 基于YOLOv8的停车对齐检测
    查看>>
    OpenCV与AI深度学习 | 基于机器视觉的磁瓦表面缺陷检测方案
    查看>>
    Opencv中KNN背景分割器
    查看>>
    OpenCV中基于已知相机方向的透视变形
    查看>>
    opencv保存图片路径包含中文乱码解决方案
    查看>>
    opencv图像分割2-GMM
    查看>>
    OpenCV(1)读写图像
    查看>>
    OpenCV:概念、历史、应用场景示例、核心模块、安装配置
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>