本文共 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,表示是否成功找到目标节点。转载地址:http://hpaoz.baihongyu.com/