链表题目 : 链表的中间结点 与 链表中倒数第k个结点(leetcode 和 牛客)

news2025/3/1 20:48:38

坚持看完,结尾有思维导图总结

快慢指针在链表中的运用

  • 链表的中间结点
    • 步骤
    • 例子分析
      • 奇数情况
      • 偶数情况
    • 程序
  • 链表中倒数第k个结点
    • 步骤
    • 解析
    • 程序

链表的中间结点

leetcode 链接
在这里插入图片描述

在这里插入图片描述

步骤

  1. 设置两个指针来遍历链表,一个叫 fast 每次跳过两个元素,一个叫 slow 每次跳过一个元素
  2. 当 fast 跳到尾的时候,slow 正好是中间节点

例子分析

奇数情况

在这里插入图片描述
奇数的时候,跳到最后一个节点

偶数情况

在这里插入图片描述
偶数时,跳到 NULL节点

程序


#include<stdio.h>
struct ListNode* middleNode(struct ListNode* head){
	struct ListNode* fast = head;
	struct ListNode* slow = head;
	
	if(fast==NULL)
	{
		return NULL;
	}
	
	//保证能够向后跳
	while(fast != NULL &&fast->next != NULL )
	{
		fast = fast->next->next;
		slow = slow->next;
	}
	return slow;
	
}

注意要判断 fast 退出的判断

链表中倒数第k个结点

牛客网链接
在这里插入图片描述

步骤

  1. 设置两个指针 一个指针叫 front 先走 k 步
  2. front 走完 k 步 后 再开始走
  3. 当front 走到尾的时候 ,slow 恰好指向倒是第k个节点

解析

在这里插入图片描述

程序

struct ListNode* FindKthToTail(struct ListNode* pListHead, int k ) {
	struct ListNode* front = pListHead;
	struct ListNode* after = pListHead;
	//先走 k 步
	while(k)
	{
		if(front == NULL)
		{
			return NULL;
		}
		front = front->next;
		k--;
	}
	
	//slow 跟上
	while(front)
	{
		front = front->next;
		after = after->next;
	}
	return after;
}

注意 : front 在k步内走完链表的可能

希望大家看完,能够有所收获
如果有错误,请指出我一定虚心改正
动动小手点赞
鼓励我输出更加优质的内容

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

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

相关文章

浅谈网络损伤仪HoloWAN的使用场景

目录一、HoloWAN 应用于卫星通讯领域1.1 卫星通讯领域的背景和挑战1.2 使用HoloWAN实现卫星⽹络仿真二、HoloWAN 应用于网络游戏2.1 网络游戏的背景和挑战2.2 使用HoloWAN模拟真实的网络环境三、HoloWAN 应用于数据中心迁移3.1 数据迁移的背景和挑战3.2 使用HoloWAN进行在线性能…

客户文章|南方医科大学李克玄团队破解肠道宏病毒与心肌病关系

近日凌恩生物合作客户南方医科大学南方医院麻醉科刘克玄团队在医学期刊《JOURNAL OF MEDICAL VIROLOGY》上发表名为“Gut microbiota dysbiosis is associated with sepsis-induced cardiomyopathy in patients: A case‒control study”研究&#xff0c;该研究利用宏基因组测序…

Imazing2023免费版苹果手机iOS数据管理软件

Imazing是一款很棒的苹果iOS管理工具&#xff0c;并且可以轻松扩大您对移动数据的控制范围&#xff0c;实现以往从未出现的功能&#xff0c;那么为了让大家更好的使用这款软件&#xff0c;因此小编就给大家带来了imazing使用教程&#xff0c;有需要的用户就一起来看看吧。一款安…

Linux安装java的JDK步骤

1.获取安装包&#xff08;服务器不通外网的话&#xff0c;自行在本机下载然后上传&#xff09; wget https://packages.baidu.com/app/jdk-8/jdk-8u121-linux-x64.tar.gz 2.创建安装目录 mkdir -p /usr/java 3.将前面下载的安装包移动到新目录 mv jdk-8u121-linux-x64.tar.g…

使用北鲲云在AWS上运行基因分析HPC任务

背景 近三十年来&#xff0c;生命科学与计算科学飞速发展。生物信息学是一门生命科学与计算科学的前沿交叉学科。生物信息学产生和迅猛发展的主要推动力来自于新一代测序等高通量技术在生命科学领域越来越广泛的应用。 基因组学是这一趋势的一个主要例子&#xff0c;其中高通量…

直播回顾|关联网络如何反团伙欺诈——标准答案版

11月10日下午15:00顶象数据科学家翼龙带来主题为《关联网络技术在业务安全中的应用》的直播。 直播内容包括常见的团伙欺诈场景、关联网络在反团伙欺诈中的作用、关联网络的技术框架&#xff0c;并就关联图谱构建和复杂网络算法展开了具体的讨论&#xff0c;最后以案例的形式形…

ElasticSearch 文档数据导入导出及两个ElasticSearch互相导入操作

文章目录一、前期安装准备二、ElasticSearch文档数据导入和导出三、两个ElasticSearch互相导入操作四、ElasticSearch版本不同是否有问题一、前期安装准备 1.先安装Node.js工具 Node.js官网下载地址&#xff1a;下载地址 双击下载完后的安装包&#xff0c;一直点下一步&#…

【日拱一卒】如何编写测试用例(下)

六、测试用例设计的误区 能发现到目前为止没有发现的缺陷的用例是好的用例&#xff1b; 首先要申明&#xff0c;其实这句话是十分有道理的&#xff0c;但我发现很多人都曲解了这句话的原意&#xff0c;一心要设计出发现“难于发现的缺陷”而陷入盲目的片面中去&#xff0c;忘记…

华为机试 - 城市聚集度

目录 题目描述 输入描述 输出描述 用例 题目解析 算法源码 题目描述 一张地图上有n个城市&#xff0c;城市和城市之间有且只有一条道路相连&#xff1a;要么直接相连&#xff0c;要么通过其它城市中转相连&#xff08;可中转一次或多次&#xff09;。城市与城市之间的道…

11月第2周榜单丨飞瓜数据B站UP主排行榜(哔哩哔哩)发布!

飞瓜轻数发布2022年11月07日-11月13日飞瓜数据UP主排行榜&#xff08;B站平台&#xff09;&#xff0c;通过充电数、涨粉数、成长指数三个维度来体现UP主账号成长的情况&#xff0c;为用户提供B站号综合价值的数据参考&#xff0c;根据UP主成长情况用户能够快速找到运营能力强的…

Java#6(类和对象及封装)

目录 一.类和对象基本介绍 1.类:是对象共同特征的描述; 2.对象:是真实存在的具体东西 如何定义类? 对象的定义和使用? 二.封装 原则:对象代表什么,就得封装什么数据,并提供数据对应的行为 1.实例理解 三.Private(私有权限) 一.类和对象基本介绍 1.类:是对象共同特征…

css :first-child 和 :first-of-type

1 :first-child p:first-child {background-color:yellow; }阅读理解&#xff1a;<p>元素的背景设为黄色 第一个子元素的背景设为黄色 父元素的第一个子元素是<p>时&#xff0c;该子元素背景设为黄色 举个栗子&#xff1a; <!DOCTYPE html> <html>…

关于java String类(源码等)分析

String 类 String声明为final &#xff0c;不可以被继承 String 实现了Serializable接口&#xff0c;表明字符串是可序列化的 String 实现了Compareble接口&#xff0c;表示String 可比较大小 String 内部定义了 final char[] value value用于存储字符串数据&#xff0c;表明…

蓝牙耳机什么牌子的好用?口碑比较好的国产蓝牙耳机推荐

对于那些经常戴耳机的人来说&#xff0c;戴上一副舒服的耳机是非常必要的。所以&#xff0c;那些口碑好&#xff0c;佩戴舒适的蓝牙耳机让大多数人都有了很好的体验感。人们之所以如此喜爱蓝牙耳机&#xff0c;一方面是因为其小巧而精致&#xff0c;另一方面则是因为其便于携带…

前端——router路由

1.路由配置 在store文件夹下&#xff0c;新建index.js文件中配置路由 /* vue3中 路由配置 */ //1.path&#xff1a;与vue2中子路由path不带“/”不同的是&#xff0c;vue3这里子路由path带了"/" //这样vue3中路由访问路径也就不是嵌套的&#xff0c;虽然路由配置这…

【深度学习】实验3答案:PyTorch实战——CIFAR图像分类

DL_class 学堂在线《深度学习》实验课代码报告&#xff08;其中实验1和实验6有配套PPT&#xff09;&#xff0c;授课老师为胡晓林老师。课程链接&#xff1a;https://www.xuetangx.com/training/DP080910033751/619488?channeli.area.manual_search。 持续更新中。 所有代码…

Python采集天气数据,做可视化分析【附源码】

知识点: 动态数据抓包requests发送请求结构化非结构化数据解析 开发环境: python 3.8 运行代码pycharm 2021.2 辅助敲代码requests 如果安装python第三方模块: win R 输入 cmd 点击确定, 输入安装命令 pip install 模块名 (pip install requests)回车在pycharm中点击Term…

RocketMQ 5.0 API 与 SDK 的演进

作者&#xff1a; 艾阳坤 RocketMQ 5.0 SDK 采用了全新的 API&#xff0c;使用 gRPC 作为通信层的实现&#xff0c;并在可观测性上做了很大幅度的提升。 全新统一的 API 此处的 API 并不单单只是接口上的定义&#xff0c;同时也规定了各个接口不同的方法和行为&#xff0c;明…

【案例实战】分布式应用下登录检验解决方案(JWT)

文章目录1.需求背景以及JWT简介2.创建Maven项目&#xff0c;搭建SpringBoot项目3.容器化急速部署MySQL4.数据库表准备5.SpringBoot整合MySQLMyBatisPlus6.MyBatisPlus逆向工程自动生成7.SpringBoot整合JWT8.开发测试接口9.开发登录接口10.开发登录拦截器11.启动验证1.需求背景以…

cookie介绍:cookie实现增删改查功能

1、cookie介绍 只能存储文本&#xff0c;只能实现在本地的存储&#xff1b;单条存储有大小限制4kB左右&#xff0c;数量限制&#xff08;一般浏览器&#xff0c;限制大概在50条左右&#xff09;&#xff1b;读取有域名限制&#xff1a;不可跨域读取&#xff0c;只能由来自写入…