ImageVerifierCode 换一换
格式:PDF , 页数:3 ,大小:214.71KB ,
资源ID:5913    下载:注册后免费下载
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenkunet.com/d-5913.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(编程判断两个链表是否相交.pdf)为本站会员(李静文)主动上传,文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文库网(发送邮件至13560552955@163.com或直接QQ联系客服),我们立即给予删除!

编程判断两个链表是否相交.pdf

1、写书评,赢取编程之美-微软技术面试心得 编程判断两个链表是否相交 给出两个单向链表的头指针(如图 3-8 所示),比如h 1 、h 2 ,判断这两个链表是否 相交。这里为了简化问题,我们假设两个链表均不带环。 图3-8 链表相交示意图 写书评,赢取编程之美-微软技术面试心得 分析与解法 这样的一个问题, 也许我们平时很少考虑。 但在一个大的系统中, 如果出现两个链表相 交的情况, 而且释放了其中一个链表的所有节点, 那样就会造成信息的丢失, 并且另一个与 之相交的链表也会受到影响, 这是我们不希望看到的。 在特殊的情况下, 的确需要出现相交 的两个链表,我们希望在释放一个链表之前知道是否有其他

2、链表跟当前这个链表相交。 【解法 一】 直观的想法 看到这个问题,我们的第一个想法估计都是,“不管三七二十一”,先判断第一个链表 的每个节点是否在第二个链表中。这种方法的时间复杂度为O(Length(h 1 ) * Length(h 2 )。可 见,这种方法很耗时间。 【解法 二】 利用 计数 的 方法 很容易想到, 如果两个链表相交, 那么这两个链表就会有共同的节点。 而节点地址又是 节点的唯一标识。 所以, 如果我们能够判断两个链表中是否存在地址一致的节点, 就可以知 道这两个链表是否相交。一个简单的做法是对第一个链表的节点地址进行 hash 排序,建立 hash 表,然后针对第二个链表的

3、每个节点的地址查询 hash 表,如果它在 hash 表中出现,那 么说明第二个链表和第一个链表有共同的节点。这个方法的时间复杂度为O(max(Length(h 1 ) + Length(h 2 )。但是它同时需要附加O(Length(h 1 )的存储空间,以存储哈希表。虽然这样做 减少了时间复杂度, 但是是以增加存储空间为代价的。 是否还有更好的方法呢, 既能够以线 性时间复杂度解决问题,又能减少存储空间? 【解法三】 由于两个链表都没有环, 我们可以把第二个链表接在第一个链表后面, 如果得到的链表 有环,则说明这两个链表相交。否则,这两个链表不相交(如图 3-9 所示)。这样我们就把 问题

4、转化为判断一个链表是否有环。 图3-9 链 表有环的情况 判断一个链表是否有环, 也不是一个简单的问题, 但是需要注意的是, 在这里如果有环, 则第二个链表的表头一定在环上, 我们只需要从第二个链表开始遍历, 看是否会回到起始点 就可以判断出来。 最后, 当然可别忘了恢复原来的状态, 去掉从第一个链表到第二个链表表 头的指向。 写书评,赢取编程之美-微软技术面试心得 这个方法总的时间复杂度也是线性的,但只需要常数的空间。 【解法四】 仔细观察题目中的图示, 如果两个没有环的链表相交于某一节点的话, 那么在这个节点 之后的所有节点都是两个链表所共有的。 那么我们能否利用这个特点简化我们的解法呢?

5、困 难在于我们并不知道哪个节点必定是两个链表共有的节点 (如果它们相交的话) 。 进一步考 虑“如果两个没有环的链表相交于某一节点的话,那么在这个节点之后的所有节点都是两个 链表共有的”这个特点,我们可以知道,如果它们相交,则最后一个节点一定是共有的。而 我们很容易能得到链表的最后一个节点,所以这成了我们简化解法的一个主要突破口。 先遍历第一个链表, 记住最后一个节点。 然后遍历第二个链表, 到最后一个节点时和第 一个链表的最后一个节点做比较,如果相同,则相交,否则,不相交。这样我们就得到了一 个时间复杂度,它为O(Length(h 1 ) + Length(h 2 ),而且只用了一个额外的指针来存储最后一 个节点。这个方法比解法三更胜一筹。 扩展问题 1. 如果链表可能有环呢?上面的方法需要怎么调整? 2. 如果我们需要求出两个链表相交的第一个节点呢?

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:文库网官方知乎号:文库网

经营许可证编号: 粤ICP备2021046453号世界地图

文库网官网©版权所有2025营业执照举报