
王道数据结构2.2.3——16、判断一个单链表是否为另一个单链表的连续子序列
如果ra和rb指针所指的节点数据不同,将ra指针移到其下一个节点,rb指针则回到链表起点。 如果ra和rb指针所指的节点数据相同,同时移动ra和rb指针各到下一个节点,继续比较。此外,还要考虑链表长度的不一致情况。最终判断是否rb指针已经到达链表末尾。
发布日期:2021-05-17 06:34:23
浏览次数:12
分类:精选文章
本文共 688 字,大约阅读时间需要 2 分钟。
思路
要同时遍历两个单链表A和B,可以采用双指针法。分别用两个指针ra和rb,分别指向A和B的下一个节点。操作步骤如下:代码
boolean findChild(LinkList A, LinkList B) { LNode ra = A.next, rb = B.next, temp = A.next; while (ra != null && rb != null) { if (ra.data != rb.data) { ra = temp.next; temp = ra; rb = B.next; } else { ra = ra.next; rb = rb.next; } } return rb == null;}
解释
代码逻辑首先将ra和rb分别初始化为A和B的下一个节点。通过while循环双向遍历两个链表:当两个节点数据不同时,ra被移到下一个节点,rb则归位到B的起点;当两个节点数据相同时,两个指针同时移动到下一个节点。最终,当某个链表遍历完毕时,函数返回true或false,表示是否成功找到目标节点。发表评论
最新留言
做的很好,不错不错
[***.243.131.199]2025年04月11日 08时42分28秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
ValueError: Unexpected end of file.
2019-03-13
六、登录(二)
2019-03-13
Liferay对union的处理
2019-03-13
初始微服务---Springcloud发展【第一期】
2019-03-13
RAFT 拜占庭将军 共识算法
2019-03-13
UE4 错误列表 error码(只记录我遇到的情况,持续添加,未完成)
2019-03-13
【.net+jquery】绘制自定义表单(含源码)
2019-03-13
【Jquery】获取当前窗口的宽度值/高度值
2019-03-13
移动开发程序员的悲哀是什么?
2019-03-13
Android 架构组件 – 让天下没有难做的 App
2019-03-13
启动MongoDB出现1053错误
2019-03-13
centOS7.6安装nginx
2019-03-13
[python复习6]正则表达式
2019-03-13
Flask操作SQLAlchemy
2019-03-13
牛客寒假4 e最小表达式
2019-03-13
JavaScript和Java重要的相异点
2019-03-13
网络对抗技术-Exp2-后门原理与实践 20181314
2019-03-13