C语言每日一题:12《数据结构》相交链表。

题目:

思路一:

1.如果最后一个节点相同说明一定有交点。 2.使用两个循环获取一下长度,同时可以获取到尾节点。 3。注意初始化lenA和lenB为1,判断下一个节点是空是可以保留尾节点的。长度会少一个,尾节点没有进入循环就不会++; (保留位节点是判断是否链表相交); 4.计算长度差的绝对值,因为不知道谁大谁小。 5.假设一个长一个短,并且定义名称代表长度的新的链表头。 6.判断+修正 7.进行长的先走差距步。 8.如果出现最后一个才相交的情况那么循环走到两个链表的节点都走到空才可以结束保证最后一个节点是被判断的。 注意(循环遍历不要动参数)
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {
          
   

    struct ListNode* curA=headA,*curB=headB;
    struct ListNode* tileA=headA,*tileB=headB;
    int lenA=1,lenB=1;

    while(tileA->next)
    {
          
   
        tileA=tileA->next;
        lenA++;
    }
    while(tileB->next)
    {
          
   
        tileB=tileB->next;
        lenB++;
    }

    if(tileA!=tileB)
    {
          
   
        //说明没有相交
        return NULL;
    }
    //说明一定相交
    int gap=abs(lenA-lenB);

    //2.谁比较大就先走差距步
    //假设
    struct ListNode* shortlist=headA,*longlist=headB;
    if(lenB<lenA)
    {
          
   
        //修正
        shortlist=headB;
        longlist=headA;
    }

    //长的先走差距补。
    while(gap--)
    {
          
   
        longlist=longlist->next;
    }

    while(shortlist&&longlist)
    {
          
   
        if(shortlist==longlist)
        {
          
   
            return longlist;
        }
        else
        {
          
   
            shortlist=shortlist->next;
            longlist=longlist->next;
        }
    }
    return NULL;
}
经验分享 程序员 微信小程序 职场和发展