链表--1.判断两个链表是否相交,若相交,求交点。(假设链表不带环)2.判断两个链表是否相交,若相交,求交点。(假设链表可能带环)

2023-11-01 04:38

本文主要是介绍链表--1.判断两个链表是否相交,若相交,求交点。(假设链表不带环)2.判断两个链表是否相交,若相交,求交点。(假设链表可能带环),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.判断两个链表是否相交,若相交,求交点。(假设链表不带环)

1.若链表不带环
则若相交只有一种方式。
这里写图片描述
方法一:
把List2链接到List1的后面,再遍历List2,如果List2有环则说明相交。且List2的头一定在环上。
这里写图片描述
方法二:
将List1与List2同时走到链表结尾,如果尾结点相同,则一定有环。
判断相交点:两个链表不一定一样长,所以先算出List1与List2的长度。然后求出两长度差len,将长的先走len步,再同时走,当他俩相遇的时候就为交点。

int Check_NoCricle(ListNode* pHead1,ListNode* pHead2)
{if(pHead1 == NULL || pHead2 == NULL)return -1;while(pHead1->Next)pHead1 = pHead1->Next;while(pHead2->Next)pHead2 = pHead2->Next;if(pHead1 == pHead2)return 1;return 0;
}ListNode* GetList_EnterNode(ListNode* pHead1,ListNode* pHead2)
{assert(pHead1 && pHead2)int len1 = 0;int len2 = 0;ListNode* pCur1 = pHead1;ListNode* pCur2 = pHead2;while(pCur1){len1++;pCur1 = pCur1->Next;}while(pCur2){len2++;pCur2 = pCur2->Next;}pCur1 = pHead1;pCur2 = pHead2;int lensub = len1-len2;if(lensub <= 0){//List2长lensub = -lensub;while(lensub){pCur2 = pCur2->Next;lensub--;}}else{//List1长while(lensub){pCur1 = pCur1->Next;lensub--;}}//走到这里两个链表长度是一样的while(pCur1 != pCur2){pCur1 = pCur1->Next;pCur2 = pCur2->Next;}return pCur1;
}

1.判断两个链表是否相交,若相交,求交点。(假设链表带环)

这里只给出思路。
若两链表可能带环

1.一个链表带环,一个链表不带环。这种情况不可能相交。
2.两个链表都带环。三种情况。这里只给出相交的两种情况。
这里写图片描述
如果交点在环外,则只有一个交点。
这里写图片描述
如果交点在环内,则有两个交点任意输出一个即可。
则先判断两个带环链表是否相交

ListNode* Find_CricleNode(ListNode* pHead1,ListNode* pHead2)
{assert(pHead1 && pHead2);ListNode* pCur1 = IsHaveCircle(pHead1);ListNode* pCur2 = IsHaveCircle(pHead2);//只要一个没有环,则不存在交点if(pCur1 == NULL  pCur2 == NULL)return GetList_EnterNode (pCur1,pCur2);//走到这里说明两个都有环ListNode* pMeet1 = FindLoopStart(pHead1);ListNode* pMeet2 = FindLoopStart(pHead2);if(pMeet1!=NULL && pMeet2!=NULL){ListNode* pTemp = pMeet1;while(pMeet1 != pTemp->Next){//这里一定要先判断第一个,并且这里输出的交点不一定一定是第一个交点。如果交点在环外则不是。if(pTemp == pMeet2)return pTenp;pTemp = pTemp->Next;}}    return NULL;
}

如果都带环且交点在环的内部,找出某一个环的入口点,输出即可。

如果环且交点在外部,则找到任意一个环入口,把环断掉。再用方法一即可。这里只给出思路。

这篇关于链表--1.判断两个链表是否相交,若相交,求交点。(假设链表不带环)2.判断两个链表是否相交,若相交,求交点。(假设链表可能带环)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/320535

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

C++链表的虚拟头节点实现细节及注意事项

《C++链表的虚拟头节点实现细节及注意事项》虚拟头节点是链表操作中极为实用的设计技巧,它通过在链表真实头部前添加一个特殊节点,有效简化边界条件处理,:本文主要介绍C++链表的虚拟头节点实现细节及注... 目录C++链表虚拟头节点(Dummy Head)一、虚拟头节点的本质与核心作用1. 定义2. 核心价值二

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用