其他分享
首页 > 其他分享> > leetcode160相交链表

leetcode160相交链表

作者:互联网

编写一个程序,找到两个单链表相交的起始节点。

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
int getlen(struct ListNode *head)
{
    int l = 0;
    while(head)
    {
        l++;
        head = head->next;
    }
    return l;
}
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {
    int a = getlen(headA);
    int b = getlen(headB);
    int i = 0;
    
    if(a>b)
    {
        for(i=0; i<a-b; i++)
        {
            headA = headA->next;
        }
    }
    else
    {
        for(i=0; i<b-a; i++)
        {
            headB = headB->next;
        }
    }
    while(headA != headB && headA)
        {
            headA = headA->next;
            headB = headB->next;
        }
        return headA;
}

 

标签:ListNode,struct,int,相交,leetcode160,链表,headB,headA,next
来源: https://blog.csdn.net/qq_43574794/article/details/98483130