我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Golang如何判断两个链表是否相交

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Golang如何判断两个链表是否相交

这篇文章主要介绍“Golang如何判断两个链表是否相交”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Golang如何判断两个链表是否相交”文章能帮助大家解决问题。

算法题:判断2个链表相交

方法一:map

步骤:

  • 遍历list1,以节点为key放入map中

  • 遍历list2,判断每个节点是否在map中,如果在则相交,且顶一个存在的节点是交点

// 定义链表节点type Node struct {val  intnext *Node}// 判断两个链表是否相交func IsIntersect(list1, list2 *Node) bool {if list1 == nil || list2 == nil {return false}m := make(map[*Node]struct{})p := list1for p != nil {m[p] = struct{}{}p = p.next}p = list2for p != nil {if _, ok := m[p]; ok {return true}p = p.next}return false}// 根据数组生成链表func New(data []int) *Node {nodes := make([]*Node, len(data))for i := 0; i < len(data); i++ {nodes[i] = &Node{val: data[i],}if i > 0 {nodes[i].next = nodes[i-1]}}return nodes[len(data)-1]}// 合并两个链表func Connect(node1, node2 *Node) *Node {if node1 == nil {return node2}if node2 == nil {return node1}p := node1for p.next != nil {p = p.next}p.next = node2return node1}

测试

func main() {data1 := []int{1, 2, 3, 4, 5}data2 := []int{6, 7, 8, 9, 10}data3 := []int{11, 12, 13, 14, 15}node1 := New(data1)node2 := New(data2)node3 := New(data3)node2 = Connect(node2, node1)  // 10,9,8,7,6,5,4,3,2,1node3 = Connect(node3, node1)  // 15,14,13,12,11,5,4,3,2,1result := data0312.IsIntersect(node2, node3)fmt.Println(result) // true}

方法二:首尾相接法

将链表1的尾指向头,然后遍历链表2,看是否能达到链表1的头,如果能则说明相交

func IsIntersect(list1, list2 *Node) bool {if list1 == nil || list2 == nil {return false}// 将链表1的尾指向头p := list1for p.next != nil {p = p.next}p.next = list1// 遍历链表2,如果能到达链表1的头则说明相交p = list2for p != nil {if p == list1 {return true}p = p.next}return false}

关于“Golang如何判断两个链表是否相交”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Golang如何判断两个链表是否相交

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Golang如何判断两个链表是否相交

这篇文章主要介绍“Golang如何判断两个链表是否相交”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Golang如何判断两个链表是否相交”文章能帮助大家解决问题。算法题:判断2个链表相交方法一:ma
2023-07-05

java怎么判断两个链表是否相交

判断两个链表是否相交的方法可以使用双指针的方式。具体步骤如下:定义两个指针p1和p2,分别指向链表1和链表2的头节点。同时遍历链表1和链表2,如果p1和p2指向的节点相同,则说明两个链表相交,返回true。如果遍历完链表1和链表2都没有
2023-10-22

Golang判断两个链表是否相交的方法详解

这篇文章主要为大家详细介绍了如何通过Golang判断两个链表是否相交,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
2023-03-14

Python中如何判断两个列表是否相等

Python中如何判断两个列表是否相等,需要具体代码示例在编程中,经常会遇到需要判断两个列表是否相等的情况。Python提供了几种方法来实现这个判断,下面将详细介绍这些方法并给出具体的代码示例。方法一:使用“==”运算符Python中的列表
2023-10-22

java如何判断两个double是否相等

在Java中,判断两个double是否相等不能直接使用`==`运算符,因为浮点数在计算机中是以二进制形式存储的,存在精度问题。应该使用`Double.compare()`方法或者自定义一个误差范围进行比较。1. 使用`Double.comp
2023-09-22

es6如何判断两个数组是否相等

这篇“es6如何判断两个数组是否相等”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“es6如何判断两个数组是否相等”文章吧。步
2023-07-04

php如何判断两个字符串是否相等

这篇文章主要讲解了“php如何判断两个字符串是否相等”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php如何判断两个字符串是否相等”吧!方法一:使用“==”运算符最常见的方法是使用“==”运
2023-07-05

Java如何判断两个Long对象是否相等

这篇文章主要介绍“Java如何判断两个Long对象是否相等”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java如何判断两个Long对象是否相等”文章能帮助大家解决问题。抛出问题:Long a =
2023-06-17

java如何判断两个对象的值是否相等

在Java中,要判断两个对象的值是否相等,需要使用对象的equals()方法。equals()方法是Object类的方法,所有的Java对象都继承了该方法。默认情况下,equals()方法比较的是两个对象的引用是否相等,即判断两个对象是否是
2023-08-16

php如何判断两个数组是否有相同值

本篇内容介绍了“php如何判断两个数组是否有相同值”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!方法:1、用array_intersect(
2023-06-30

c语言如何判断两个矩阵是否相等

这篇文章主要介绍了c语言如何判断两个矩阵是否相等的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇c语言如何判断两个矩阵是否相等文章都会有所收获,下面我们一起来看看吧。代码如下:#includev
2023-06-17

oracle如何判断两列值是否相等

在Oracle中,可以使用等号(=)运算符来判断两列的值是否相等。以下是一些示例:1. 使用等号运算符进行比较:```sqlSELECT * FROM 表名 WHERE 列1 = 列2;```2. 使用等号运算符和其他条件进行比较:```s
2023-08-09

php如何判断两数组是否有交集

本篇内容介绍了“php如何判断两数组是否有交集”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!判断步骤:1、利用array_intersect
2023-07-02

java怎么判断两个对象是否相等

java中可以使用equals()方法判断两个对象是否相等,equals() 方法用于将字符串与指定的对象比较。如果给定对象与字符串相等,则返回 true;否则返回 false。该方法的源码如下:public boolean equals(Object obj
java怎么判断两个对象是否相等
2015-04-07

php如何判断两数相除是否有余

本篇内容主要讲解“php如何判断两数相除是否有余”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“php如何判断两数相除是否有余”吧!php判断相除是否有余的方法:1、使用“%”运算符计算两数相除,
2023-06-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录