数据结构——链表专题2

news/2024/9/22 21:05:42/

文章目录

  • 一、返回倒数第k 个节点
  • 二、链表的回文结构
  • 三、相交链表

一、返回倒数第k 个节点

原题链接:返回倒数第k 个节点
在这里插入图片描述

利用快慢指针的方法:先让fast走k步,然后fast和slow一起走,直到fast为空,最后slow指向的结点就是目标结点
在这里插入图片描述
在这里插入图片描述

int kthToLast(struct ListNode* head, int k)
{struct ListNode* slow = head;struct ListNode* fast = head;while(k--){fast = fast->next;}while(fast){fast = fast->next;slow = slow->next;}return slow->val;
}

二、链表的回文结构

原题链接:链表的回文结构

在这里插入图片描述

对于这道题,可以分为三个步骤

首先,找到链表的中间结点mid
其次,从中间结点开始将链表逆置
最后,将指向原链表的指针A与指向逆置后的指针rmid的结点数据进行比较,遍历链表

在这里插入图片描述

class PalindromeList
{
public://找到中间结点struct ListNode* FindMid(struct ListNode* head){struct ListNode* slow = head;struct ListNode* fast = head;while(fast && fast->next){fast = fast->next->next;slow = slow->next;}return slow;}//逆置链表struct ListNode* Reserve(struct ListNode* head){struct ListNode* n1 = NULL;struct ListNode* n2 = head;struct ListNode* n3 = n2->next;while(n2){n2->next = n1;n1 = n2;n2 = n3;if(n3){n3 = n3->next;}}return n1;}bool chkPalindrome(ListNode* A){struct ListNode* mid = FindMid(A);struct ListNode* rmid = Reserve(mid);while(A && rmid){if(A->val != rmid->val){return false;}A = A->next;rmid = rmid->next;}return true;}
};

三、相交链表

原题链接:相交链表
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

关于链表的相交,不是交叉形状,而是Y字形

在这里插入图片描述

那么如何解决这个问题呢?
可以创建两个指针变量,分别指向各自的头结点,然后遍历找到尾结点并且比较尾结点是否相同,相同就表示两个链表一定相交,不相同直接返回NULL
在这里插入图片描述
在这里插入图片描述

确定两个链表相交,那么如何找到相交的头结点呢?
鉴于两个链表的长度不一定相等,应该在上述遍历链表的时候记录下各自链表的长度,然后让指向长度大的链表的指针先走差距步,这样两个指针距离相交结点的距离就相等了,直接循环遍历找到目标结点即可

在这里插入图片描述

那么哪个链表更长呢?
这里可以用假设法,假设长的为A,后面再判断是否A与B的大小,这样可以省了不少代码量,更加方便
在这里插入图片描述
在这里插入图片描述

struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB)
{struct ListNode* pcurA = headA;int lenA = 1;struct ListNode* pcurB = headB;int lenB = 1;while(pcurA->next){pcurA = pcurA->next;lenA++;}while(pcurB->next){pcurB = pcurB->next;lenB++;}//判断尾结点是否相等if(pcurA != pcurB){return NULL;}//假设法//假设longnode = headA   shortnode = headBint gap = abs(lenA - lenB);struct ListNode* longnode = headA;struct ListNode* shortnode = headB;if(lenA < lenB){longnode = headB;shortnode = headA;}//走差距步while(gap--){longnode = longnode->next;}while(longnode != shortnode){longnode = longnode->next;shortnode = shortnode->next;}return longnode;
}

http://www.ppmy.cn/news/1455359.html

相关文章

Node.js爬虫在租房信息监测与分析中的应用

在当今数字化时代&#xff0c;房地产市场的信息变化迅速&#xff0c;租房信息的获取和分析对于租房者和房东都至关重要。随着互联网技术的发展&#xff0c;利用爬虫技术来监测和分析租房信息已成为一种常见的做法。本文将探讨如何利用Node.js爬虫在租房信息监测与分析中的应用前…

mysql学习手记

1.视图 简单一句&#xff1a;将需要重复使用的mysql语句放到视图中去 视图优点&#xff1a;1.简化查询 2.减少数据库改动的成本 3.限制访问 -- 创建视图 CREATE VIEW view_name AS SELECT column1, column2, ... FROM table_name WHERE condition;-- 使用视图 SELECT * FROM…

Rust Course学习(编写测试)

如果友友你的计算机上没有安装Rust&#xff0c;可以直接安装&#xff1a;Rust 程序设计语言 (rust-lang.org)https://www.rust-lang.org/zh-CN/ Introduce 介绍 Testing in Rust involves writing code specifically designed to verify that other code works as expected. It…

【QEMU系统分析之实例篇(十八)】

系列文章目录 第十八章 QEMU系统仿真的机器创建分析实例 文章目录 系列文章目录第十八章 QEMU系统仿真的机器创建分析实例 前言一、QEMU是什么&#xff1f;二、QEMU系统仿真的机器创建分析实例1.系统仿真的命令行参数2.创建后期后端驱动qemu_create_late_backends()qtest_serv…

Llama3-Tutorial之LMDeploy高效部署Llama3实践

Llama3-Tutorial之LMDeploy高效部署Llama3实践 Llama 3 近期重磅发布&#xff0c;发布了 8B 和 70B 参数量的模型&#xff0c;lmdeploy团队对 Llama 3 部署进行了光速支持&#xff01;&#xff01;&#xff01; 书生浦语和机智流社区同学光速投稿了 LMDeploy 高效量化部署 Llam…

茅台葡萄酒打出节日新式营销“组合拳”,两月内落地品鉴会超千桌

执笔 | 尼 奥 编辑 | 古利特 2024年1-3月酒类进出口数据显示&#xff0c;葡萄酒进口量微增3.66%&#xff0c;进口额同比下滑11%&#xff0c;一季度整体跌势大缓&#xff0c;逐步走出普遍低迷的行情。与之相反的是&#xff0c;作为国产葡萄酒代表的茅台葡萄酒继续保持向上的战…

算法系列--BFS解决拓扑排序

&#x1f495;"请努力活下去"&#x1f495; 作者&#xff1a;Lvzi 文章主要内容&#xff1a;算法系列–算法系列–BFS解决拓扑排序 大家好,今天为大家带来的是算法系列--BFS解决拓扑排序 前言:什么是拓扑排序 拓扑排序–解决有顺序的排序问题(要做事情的先后顺序) …

《深入理解kafka-核心设计与实践原理》第三章:消费者

第三章&#xff1a;消费者 3.1 消费者与消费组 3.1.1 消费者(Consumer) 3.1.2 消费组(Consumer Group) 3.1.3 消息投递模式 3.2 客户端开发 3.2.1 必要的配置参数 3.2.2 订阅主题与分区 3.2.3 反序列化 3.2.4 消费消息 3.2.5 位移提交 3.2.5.1 offset 3.2.5.2 消费后的提交方式…