Leetcode刷题

题目如下:

在这里插入图片描述
这道题呢,这里我写出了两种解决办法,一种遍历链表来得出中间结点,一种通过快慢指针来得出中间结点

第一种:

遍历:

首先我们设置一个计数器count,来记录链表的长度,写一个函数来遍历链表,返回

count的一半的大小,即为这个链表的中间结点。(在代码的最前面,写一个typedef方便后续命名结构体)

 typedef struct ListNode ListNode; 
int lenl(ListNode* head){ListNode* tail=head;int count=0;while(tail){count++;tail=tail->next;}return count/2;}

我们获取了中间结点之后,我们只需要将头结点设置为这个中间结点就可以了

struct ListNode* middleNode(struct ListNode* head) {int len=lenl(head);while(len>0){head=head->next;len--;}return head;}

这里我们重点需要知道的是,while 的循环条件,len>=0还是len>0

分析;

如果我们循环条件为len>=0

这里,以我们的示例一为例来解释
在这里插入图片描述
首先,我们的 len 通过计算得知为 2 ,如果len>=0的话,那么

第一次循环 len = 2进入循环
此时head向前,到达2的位置

第二次循环 len=1进入循环
此时head向前,到达3的位置

第三次循环 len=0 进入循环
此时head向前,到达4的位置

我们来验证一下:
在这里插入图片描述
一旦我将循环的结束条件写为len>=0那么就会导致头结点多向前走一步,所以我们这里应该为len>0,改正后,我们再来提交一下。
在这里插入图片描述

OK,这样就过辣!

第一种方法大家可能很容易想到,但是第二种方法用途非常广泛,使用其的地方也特别多——快慢指针

先来根据一个小学公式:a=2c;
如果这里a代表了链表的总长度,那么c就代表链表长度的一半

链表分为空链表,奇数链表,偶数链表
在这里插入图片描述
题目规定,本题没有空链表的出现,所以我们这里只讨论奇数和偶数链表。
首先我们来看奇数链表。

上图,我们分析一下:

在这里插入图片描述

当我们的fast指针走到链表的最后一个元素,我们的slow指针刚好落在我们的中间结点上,此时我们的fast就不能再向前了,因为我们的fast的next已经是空了,我们如果还要继续向前的话,就会造成解引用空指针的情况发生,进而导致程序报错。

偶数链表:
在这里插入图片描述
当我们的fast指针走到NULL的时候,我们的slow指针刚好落在我们的中间结点上,此时我们的fast就不能再向前了,因为我们的fast已经是空了,我们如果还要继续向前的话,就会造成解引用空指针的情况发生,进而导致程序报错。

下来我们具体的写一下代码:

struct ListNode* middleNode(struct ListNode* head) {ListNode* slow=head;ListNode* fast=head;while(fast&&fast->next){slow=slow->next;fast=fast->next->next;}return slow;
}

我们在这里需要注意的是,我们的循环条件一定是fast&&fast->next
原因:如果我们先判断fast->next,当链表是一个偶数链表的时候fast自身已经为空了,无法解引用,会导致程序报错,所以,我们这里应该首先判断fast为不为空,顺序不能交换。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/9988.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

游戏开发--C#面试题

游戏开发--C#面试题 C#1. 值类型和引用类型的区别2. 重载和重写的区别3. ArrayList和List的区别4. List底层是什么实现的?5. 抽象类和接口的区别6. 静态成员和⾮静态成员的区别7. 装箱和拆箱是指什么?8. 值和引用类型在变量赋值时的区别是什么&#xff1…

# 设置ubuntu为中文后,如何保留用户家目录等文件夹名为英文

设置ubuntu为中文后,如何保留用户家目录等文件夹名为英文 一、问题描述: 当我们安装完ubuntu系统后,通过【系统设置】,在【语言支持】里,设置为【汉语(中国)】,这时在终端中显示文…

STM32—独立看门狗(IWDG)和窗口看门狗(WWDG)

概述: WDG(Watchdog) 看门狗,看门狗可以监控程序的运行状态,当程序因为设计漏洞、硬件故障、电磁干扰等原因,出现卡死或跑飞现象时,看门狗能计时复位程序,避免程序陷入长时间的罢工状态,保证系…

Chrome与火狐哪个浏览器的性能表现更好

在数字时代,浏览器是我们日常生活中不可或缺的工具。无论是工作、学习还是娱乐,一个好的浏览器都能显著提高我们的效率和体验。市场上有许多优秀的浏览器,其中Google Chrome和Mozilla Firefox无疑是最受欢迎的两款。本文将比较这两款浏览器的…

现在国内优秀的广告联盟有哪些?

广告联盟是网络广告效果营销的主流方式之一,广告联盟的变现方式多种多样,主要有以下四种 CPA:按照下载或者注册进行付费(软件平台或游戏试玩平台)CPS:按照成交进行付费(淘宝客)CPM&…

机器学习,生成式AI ,LLM大模型,人工智能,他们之间的关系是什么?有什么不同?

这些概念都是现代计算机科学和人工智能领域的重要组成部分,它们之间既有联系,也有区别。以下是它们的关系和不同之处: 人工智能 (AI) 两个回答 人工智能是一个广义的概念,指的是计算机系统能够执行通常需要人类智能才能完成的任务…

[全网最细数据结构完整版]第七篇:3分钟带你吃透队列

目录 1->队列的概念及结构 2->队列的实现 2.1定义队列基本结构 struct QueueNode 和 struct Queue 2.2队列初始化函数 QueueInit 函数 2.3队列销毁函数 QueueDestroy 函数 2.4队列插入数据函数 QueuePush 函数 2.5判断队列是否为空,空返回true,非空返回false 2.6队列删…

点阵数显驱动IC数显LED驱动芯片VK1651

产品品牌:永嘉微电/VINKA 产品型号:VK1651 封装形式:SOP16 产品年份:新年份 产品简介:VK1651是一种带键盘扫描电路接口的 LED 驱动控制专用芯片,内部集成有数据锁存器、LED 驱动、键盘扫描等电路。SEG脚…

【进阶】java基础之集合(2)数据结构<树>

文章目录 二叉树的内部结构二叉查找树平衡二叉树平衡二叉树的旋转机制 二叉树的内部结构 二叉查找树 二叉查找树,又称二叉排序树或者二叉搜索树 特点: 每一个节点上最多有两个子节点任意节点左子树上的值都小于当前节点任意节点右子树上的值都大于当前节点 二叉…

积分接口被刷爆,全体一个月降薪20%,这个项目我们遗漏了什么?

有一些往事总是会在酒后提起 我问朋友,在工作上有什么事情是到现在还记忆尤新的? 我朋友一个激灵坐起来,点上一支烟,只见烟头亮了4、5下,才见他吐出一口烟来,说道:“那还真有” 起因 刚参加…

AWTK-LINUX-FB实现多点触摸

两周前的一个地图,需要做手势缩放的功能,比较忙就没有发出来,这次抽时间记录一下实现的过程。 AWTK官方有对实现多点触摸做过描述,可惜只有STM32的实现例子,跟Linux的差别还是比较大的,好在tslib有多点触摸…

NRF52832学习笔记(41)——添加串口库libuarte

一、背景 由于板子上不支持硬件流控,在使用 app_uart_fifo 库接收串口大数据时,频繁报 APP_UART_COMMUNICATION_ERROR 错误,多次重新初始化后,串口也不再产生中断了。查看官方论坛后决定使用串口异步库 libuarte。 二、简介 Li…

ORU 的 Open RAN 管理平面 (M 平面)

[TOC](ORU 的 Open RAN 管理平面 (M 平面)) ORU 的 Open RAN 管理平面 (M 平面) https://www.techplayon.com/open-ran-management-plane-m-plane-for-open-radio-unit/ ORU M 平面 在 ORAN 中,设置参数的 O-RU 管理功能是通过 M-Plane 完成的。管理功能包括 O-…

MQ的基础知识

一.什么是MQ 其实就是不同的程序之间的一种的通信方式,通过将消息发送到中间件里面然后中间件就会将这个消息发送给相应的服务进行一个消息的消费,这个时候就会进行一些的业务逻辑的处理,这个方式提高了整个系统的可靠性,拓展性以及灵活性.常见的类型为Aapache Kafaka&#xf…

蓝牙OPP协议详解及Android实现

文章目录 前言一、什么是蓝牙OPP协议?二、OPP协议工作流程1. 设备配对和连接2. 启动 OPP 服务3. 发送对象4. 传输对象5. 传输完成6. 断开连接 三、 Android OPP协议实现1. 启动 OPP 服务器(接收方)2. 发送文件(发送方)…

医学可视化之涟漪图

在医学领域,数据可视化能够帮助我们更直观地理解和分析复杂的信息。涟漪图作为一种独特的可视化工具,具有重要的作用、价值和广泛的使用场景。 一、涟漪图的特点 涟漪图是一种基于地理位置的可视化图表,它通过在地图上显示不同大小或颜色的…

定义宏将整数的二进制的奇数位和偶数位互换位置

假设这个数为n00000000 00000000 00000000 00001101——13 1.思路 1.1 奇数位:00000000 00000000 00000000 00000101 但是怎么获得奇数位呢?——进行按位与运算 不懂如何运算的可以看我主页的详解操作符-CSDN博客,该章详细写了各个操作符如何…

快要结束的大学时光

目录 大一 大一上学期 Java HTMLCSS 大一下学期 HTMLCSSJS JAVA python 大二 大二上学期 Java 原型 前端 大二下学期 前端 数据结构 Android BootStrap JavaWeb ios程序设计 软件测试​编辑 大三 大三上学期 小程序 大三下学期 JavaWeb 整理数据库 大…

高效实现MySQL数据集成的具体案例分享

MySQL数据集成案例分享:1–BI秉心-店铺信息表–store_z–>store 在数据驱动的业务环境中,如何高效、可靠地实现数据集成是每个企业面临的重要挑战。本文将聚焦于一个具体的系统对接集成案例:将MySQL中的店铺信息表store_z的数据集成到另一…

[Docker#3] LXC | 详解安装docker | docker的架构与生态

目录 1.LXC容器操作 安装LXC LXC容器操作步骤 2.理论 LXC 是什么? Docker 是什么 Docker 和虚拟机的区别 Docker 和 JVM 虚拟化的区别 Docker 版本 ⭕Docker 官方网站(建议收藏) Docker 架构 生活案例 Docker 生态 Docker 解决…