码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode每日一练 —— 876. 链表的中间结点


    🌟 前言

    Wassup guys!我是Edison 😎

    今天是 LeetCode 上的 leetcode 876. 链表的中间结点

    Let’s get it!

    在这里插入图片描述


    文章目录

    • 1. 题目分析
    • 2. 题目图解
      • 🍑 奇数情况
      • 🍑 偶数情况
    • 3. 代码实现


    1. 题目分析

    给定一个头结点为 head 的非空单链表,返回链表的中间结点。
     
    如果有两个中间结点,则返回第二个中间结点。

    示例 1:
    在这里插入图片描述

    示例 2:
    在这里插入图片描述

    2. 题目图解

    这道题用的方法是 快慢指针法;

    (1)定义慢指针 slow 一次走 1 步;
     
    (2)定义快指针 fast 一次走 2 步;

    🍑 奇数情况

    当链表为 奇数 个时,首先,slow 和 fast 都指向第一个节点(如图所示👇)
    在这里插入图片描述

    然后 slow 一次走 1 步,fast 一次走 2 步,动图演示👇
    在这里插入图片描述
    当 fast 走到 尾节点 的时候,slow 指向的就是 中间节点

    🍑 偶数情况

    当链表为 偶数 个时,首先,slow 和 fast 都指向第一个节点(如图所示👇)
    在这里插入图片描述

    然后 slow 一次走 1 步,fast 一次走 2 步,动图演示👇
    在这里插入图片描述

    可以看到,当 fast 走到 NULL 时,slow 指向的就是 中间节点;

    总结:

    (1)当链表的节点数为 奇数 时,循环结束的条件就是 fast 走到 尾节点;
     
    (2)当链表的节点数为 偶数 时,循环结束的条件就是 fast 走到 NULL;

    3. 代码实现

    接口代码

    struct ListNode* middleNode(struct ListNode* head){
        struct ListNode* slow, *fast;
        slow = fast = head
        while (fast && fast->next) {
            slow = slow->next;
            fast = fast->next->next;
        }
        return slow;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    提交结果
    在这里插入图片描述

    还要注意一点:在 while 循环判断部分,写的是继续的条件,想的是结束的条件!

  • 相关阅读:
    FiRa标准UWB MAC实现(三)——距离如何获得?
    在一台Ubuntu服务器中部署Ceph分布式存储
    【C语言】模拟实现字符串函数(下)
    使用vue实现简易的音乐播放器
    工作小计-GPU硬编以及依赖库 nvcuvid&nvidia-encode
    android NDK 开发包,网盘下载,不限速
    携号转网查询易语言代码
    论文阅读:ECAPA-TDNN
    自定义 View 可以播放一段视频
    122. 买卖股票的最佳时机 II
  • 原文地址:https://blog.csdn.net/m0_63325890/article/details/125984875
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号