查找两个单链表的公共节点

查找两个单链表的公共节点

    算法思路:首先要明白单链表有公共节点的情况是什么,因为单链表中每个节点的next指针是唯一的,所以当存在公共节点的时候,其后面的所有节点也都是相同的,所以这时的链表是一个“Y”型如图所示,而不是我们惯性思维想到的“X”型。根据这个结论可知,如果两个链表存在公共节点的话,它们的尾结点也肯定是相同的。

    明白了有公共节点的链表构造之后就好办了,假设两个链表的长度分别是 len1 和 len2 

    第一种暴力方法:遍历第一个链表的节点,循环嵌套遍历第二个链表的所有节点,直到找到相同的节点。时间复杂度为O(len1*len2),这种方法实现比较简单,但是效率不高,这里就不放出来。

    第二种优化的方法:两个链表自从公共节点开始,之后的长度都是相同的,所以只要遍历两个链表长度一样的地方,这样可以减少遍历的次数。

      先得到两个链表的长度, longptr指向较长的链表,shortptr指向较短的链表,dist用来存储两个链表长度的差值,先将longptr后移dist个长度,这样能保证之后遍历的次数相等,然后就可以通过一次遍历比较完所有的节点。具体实现代码如下。

//查找两个链表的公共节点
LNode* Search_SamNode(LinkList L1,LinkList L2){
    //获取两个链表的长度 dist表示长度差
    int len1 = Length(L1),
        len2 = Length(L2),
        dist;
    LNode* longptr,shortptr;
    if(len1 > len2){
        dist = len1 - len2;
        longptr = L1;
        shortptr = L2;
    }else{
        dist = len2 - len1;
        longptr = L2;
        shortptr = L1;
    }
    //将长指针后移dist,保证两个指针同步
    while(dist--)
        longptr = longptr->next;
    while(longptr != NULL){
        if(longptr == shortptr)
            return longptr;
        else{
            longptr = longptr->next;
            shortptr = shortptr->next;
        }
    }
    return NULL;
}

  • 9
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值