Topic describes

52. The first common node of two linked lists

Their thinking

Idea 1: Front and back double Pointers (several nodes)

Double Pointers actually mean that one pointer takes n steps first and the other pointer moves at the same speed as the previous one. Use this idea is also learning algorithm brush LeetCode The KTH last node in a linked list.

Find the first common node of two linked lists, return null if not.

  • Figure out the length of the two lists, then compare the length of the two lists, and figure out the difference between the two lists, i.e. the long list takes the Delta step first than the short one.

  • Both lists go together, returning if an equal node is encountered, and null otherwise

The complete code


/** * Definition for singly-linked list. * function ListNode(val) { * this.val = val; * this.next = null; *} * /

/ * * *@param {ListNode} headA
 * @param {ListNode} headB
 * @return {ListNode}* /
const getNodeNumber = (head) = > {
    let count = 0;
    while(head){
        head = head.next;
        count ++;
    }
    return count;
}

var getIntersectionNode = function(headA, headB) {
    // Calculate the length of the two lists separately and find delta
    let countA = getNodeNumber(headA)
    let countB = getNodeNumber(headB)
    let shorter =  countA > countB ? headB : headA
    let longer = countA > countB ? headA : headB

    let delta = Math.abs(countA - countB )

    // Longer Indicates the number of advanced steps
    let node1 = longer
    for(let i = 0; i < delta; i++){
        node1 = node1.next;
    }

    // Iterate over two lists, if they meet, the first common node.
    let node2 = shorter;
    while(node1 ! = node2){ node1 = node1.next; node2 = node2.next; }return node1
};

Copy the code

Complexity analysis

Time complexity: O(m+ N)

The two lists are traversed twice, the first time to get the number of nodes of the two lists, and the second time to find the first common node of the two lists.

Space complexity: O(1)

Unneeded nodes to save the linked list.

Idea 2: Stack

In this case, the top of the stack is the tail of the two linked lists. According to this problem, the first common node can be found only by searching forward from the front and tail of the linked list. Therefore, we let the elements of the two stacks exit the stack at the same time and compare whether the nodes are equal. If an unequal node is encountered, the first public node has just been passed. Return the public node.

  • Push two linked lists onto the stack

  • The elements of both stacks are removed from the stack at the same time, and the same nodes are updated. If different nodes are encountered, the loop will exit and the same nodes will be returned.

The complete code


/** * Definition for singly-linked list. * function ListNode(val) { * this.val = val; * this.next = null; *} * /

/ * * *@param {ListNode} headA
 * @param {ListNode} headB
 * @return {ListNode}* /

var getIntersectionNode = function(headA, headB) {
    // Build two stacks
    let stack1 = [];
    let stack2 = [];
    let node1 = headA;
    while(node1){
        stack1.push(node1)
        node1 = node1.next;
    }
    let node2 = headB;
    while(node2){
        stack2.push(node2)
        node2 = node2.next;
    }
    
    // The nodes of both stacks are removed and compared at the same time, and the last same node is updated at the same time.
    let firstCommonNode = null;
    while(stack1.length && stack2.length){
        const cur1 = stack1.pop();
        const cur2 = stack2.pop();
        if(cur1 ! == cur2){break;
        }
        firstCommonNode = cur1; 
    }

    return firstCommonNode
};

Copy the code

Complexity analysis

Time complexity: O(m+ N)

Space complexity: O(m+n) requires two secondary stacks