检查两个链接列表是否合并如果是这样,在哪里?

如何解决检查两个链接列表是否合并如果是这样,在哪里?

如果

  • “不允许修改”是指“您可以更改,但最终应将其还原”,并且
  • 我们可以将列表重复 两次

以下算法将是解决方案。

首先,数字。假设第一个列表的长度为a+c,第二个列表的长度为b+c,其中c是它们共同的“尾巴”的长度(在合并点之后)。让我们将它们表示如下:

x = a+c
y = b+c

由于我们不知道长度,因此我们将进行计算xy而无需进行其他迭代;您将看到如何。

然后,我们迭代每个列表,并在迭代时反转它们!如果两个迭代器同时到达合并点,那么我们仅通过比较就可以找到它。否则,一个指针将在另一指针之前到达合并点。

之后,当另一个迭代器到达合并点时,它将不会继续前进到通用尾部。相反,它将返回到之前已达到合并点的列表的前一个开始!因此,在到达更改列表的末尾(即另一个列表的前一个开始)之前,他将进行a+b+1总计迭代。叫它z+1

首先到达合并点的指针将继续迭代,直到到达列表的末尾。计算得出的迭代次数应等于x

然后,该指针进行迭代,并再次反转列表。但是现在它不会回到原来的列表的开头了!相反,它将转到另一个列表的开头!计算得出的迭代次数应等于y

因此,我们知道以下数字:

x = a+c
y = b+c
z = a+b

从中我们确定

a = (+x-y+z)/2
b = (-x+y+z)/2
c = (+x+y-z)/2

解决了问题。

解决方法

这个问题可能很旧,但是我想不出答案。

假设有两个不同长度的列表,它们 合并在一个点上 ;我们如何知道合并点在哪里?

条件:

  1. 我们不知道长度
  2. 我们应该只解析每个列表一次。

两个合并的链表的示例。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?