[牛客网刷题 Day2] JZ52 两个链表的第一个公共结点(没做出来)双指针巧解

本文主要是介绍[牛客网刷题 Day2] JZ52 两个链表的第一个公共结点(没做出来)双指针巧解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述:

在这里插入图片描述

思考过程:

好像想的太复杂了,首先固定phead1,寻找val一样的phead2,找到的话,就都往右移动一位;否则phead+1。可是需要注意好多好多的边界啊,写了好久好久,最后还是好几个用例通不过,只能根据用例慢慢改,可是怎么改都不对。o(╥﹏╥)o

class Solution:def FindFirstCommonNode(self , pHead1 , pHead2):# write code hereif pHead1==None or pHead2==None:return Nonedummy2 = pHead2while pHead1.next:while pHead1.val != pHead2.val:pHead2 = pHead2.next# 找完了都找不到相同值,l1+1,l2返回初始位置if pHead2 == None:pHead1 = pHead1.nextpHead2 = dummy2if pHead1 == None:return None# 找到相同值,都移动一位,dummy重新赋值else:dummy2 = pHead2if not(pHead1.next and pHead2.next):pHead2 = dummy2continuewhile pHead1.next or pHead2.next:if pHead1.next.val == pHead2.next.val:pHead1 = pHead1.nextpHead2 = pHead2.nextif pHead1.next == None and pHead2.next == None:return dummy2else:pHead1 = pHead1.nextif pHead1 == None:return pHead2.nextbreakelse: return dummy2return None

答案:

常规思路,跟我的思路差不多,但是他用到了哈希表。
啊啊啊,原来链表是可以比较的!可以使用in,可是我的编译器不能这样操作。。。
所以我是能做出这道题的呢!

啊啊啊啊啊啊,发现问题了!!我初始化链表的时候搞错了!应该创建三个链表,前两个再指向第三个呢!
在这里插入图片描述

常规思路就是用一个哈希集合来存储第一个链表遍历后的所有节点;接着遍历第二个链表,与哈希集合中的节点进行比较

如果第二个链表中节点不存在于哈希集合中,那么移动到下一个节点再比较
否则,节点存在于哈希集合中,返回第二个链表的该节点(他就是我们要找的第一个公共节点)。
PS:如果比较到最后一个节点发现,第二个链表中的节点都不存在于哈希集合中,那么说明这两个链表不相交!直接返回None即可。

# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None#
# 
# @param pHead1 ListNode类 
# @param pHead2 ListNode类 
# @return ListNode类
#第一种解法:哈希
class Solution:def FindFirstCommonNode(self , pHead1 , pHead2 ):# write code here#首先判断两个链表是否为空if pHead1 is None or pHead2 is None:return None#定义链表1 的集合set_A = set()node1, node2 = pHead1, pHead2 #定义两个节点#遍历链表 1 ,把每个节点加入集合中while node1:set_A.add(node1)node1 = node1.next#遍历链表2 看当前节点是否在 集合中;如果存在,当前节点就是要找的第一个公共节点;否则继续比较下一个节点。#这里还要注意,如果遍历完链表 B,发现所有节点都不在集合中,则说明两个链表不相交,返回None。while node2:if node2 in set_A:return node2node2 = node2.nextreturn None

还有一个复杂的双指针思路,啊!
哇!太巧妙了吧!原理是:走一遍pHead1,再走一遍pHead2的总路程一定是相等的!

# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None
# @param pHead1 ListNode类 
# @param pHead2 ListNode类 
# @return ListNode类
#第二种解法:双指针
class Solution:def FindFirstCommonNode(self , pHead1 , pHead2 ):# write code here#首先判断两个链表是否为空if pHead1 is None or pHead2 is None:return None#使用双指针思路进行判断p1, p2 = pHead1, pHead2 #创建两个指针,分别指向两个链表的头节点#当指针指向的两个节点不相等:while p1 != p2:if p1:p1 = p1.next           #同时更新两个指针else:p1 = pHead2#直到p1走完了自己的节点,p2也走完了自己的节点,此时p1换到p2的这条道上;同理p2也走到p1的道上#两者还是每次都移动到下一个节点,最终p1会跟p2在某一个节点相遇,相遇的这个节点就是他们的公共节点!if p2:p2 = p2.nextelse:p2 = pHead1return p1                  #由于没有交点的时候,两个链表最后都会出现都是None值,所以此时返回的p1 = None          

这篇关于[牛客网刷题 Day2] JZ52 两个链表的第一个公共结点(没做出来)双指针巧解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

SpringBoot自定义注解如何解决公共字段填充问题

《SpringBoot自定义注解如何解决公共字段填充问题》本文介绍了在系统开发中,如何使用AOP切面编程实现公共字段自动填充的功能,从而简化代码,通过自定义注解和切面类,可以统一处理创建时间和修改时间... 目录1.1 问题分析1.2 实现思路1.3 代码开发1.3.1 步骤一1.3.2 步骤二1.3.3

java两个List的交集,并集方式

《java两个List的交集,并集方式》文章主要介绍了Java中两个List的交集和并集的处理方法,推荐使用Apache的CollectionUtils工具类,因为它简单且不会改变原有集合,同时,文章... 目录Java两个List的交集,并集方法一方法二方法三总结java两个List的交集,并集方法一

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

C#比较两个List集合内容是否相同的几种方法

《C#比较两个List集合内容是否相同的几种方法》本文详细介绍了在C#中比较两个List集合内容是否相同的方法,包括非自定义类和自定义类的元素比较,对于非自定义类,可以使用SequenceEqual、... 目录 一、非自定义类的元素比较1. 使用 SequenceEqual 方法(顺序和内容都相等)2.

电脑没有仿宋GB2312字体怎么办? 仿宋GB2312字体下载安装及调出来的教程

《电脑没有仿宋GB2312字体怎么办?仿宋GB2312字体下载安装及调出来的教程》仿宋字体gb2312作为一种经典且常用的字体,广泛应用于各种场合,如何在计算机中调出仿宋字体gb2312?本文将为您... 仿宋_GB2312是公文标准字体之一,仿China编程宋是字体名称,GB2312是字php符编码标准名称(简