[摘要]本篇文章给大家带来的内容是关于php如何实现找出两个链表的第一个公共结点(代码实例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。输入两个链表,找出它们的第一个公共结点两个单链表,...
本篇文章给大家带来的内容是关于php如何实现找出两个链表的第一个公共结点(代码实例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
输入两个链表,找出它们的第一个公共结点
- 两个单链表,有公共结点,那么必然,尾部公用 
- 找出链表1的长度,找出链表2的长度,长的链表减去短的链表得出一个n值 
- 长的链表先走n步,两个链表再同时移动 
- 两个链表相交点就是第一个公共结点
 
 
list1 list2
len1 len2
if len1 > len2
    n=len1-len2
    for i=0;i<n;i++
        list1=list1->next
else
    n=len2-len1
    for i=0;i<n;i++
        list2=list2->next
while list1!=null
    if list1==list2 
        return list1
    list1=list1->next
    list2=list2->next
return null