• 面试算法23:两个链表的第1个重合节点


    题目

    输入两个单向链表,请问如何找出它们的第1个重合节点。例如,图4.5中的两个链表的第1个重合节点的值是4。
    在这里插入图片描述

    分析

    首先遍历两个链表得到它们的长度,这样就能知道哪个链表比较长,以及长的链表比短的链表多几个节点。在第2次遍历时,第1个指针P1在较长的链表中先移动若干步,再把第2个指针P2初始化到较短的链表的头节点,然后这两个指针按照相同的速度在链表中移动,直到它们相遇。两个指针相遇的节点就是两个链表的第1个公共节点。
    在这里插入图片描述

    public class Test {
        public static void main(String[] args) {
            ListNode listNode1 = new ListNode(1);
            ListNode listNode2 = new ListNode(2);
            ListNode listNode3 = new ListNode(3);
            ListNode listNode4 = new ListNode(4);
            ListNode listNode5 = new ListNode(5);
            ListNode listNode6 = new ListNode(6);
            ListNode listNode7 = new ListNode(7);
            ListNode listNode8 = new ListNode(8);
    
            listNode1.next = listNode2;
            listNode2.next = listNode3;
            listNode3.next = listNode4;
            listNode4.next = listNode5;
            listNode5.next = listNode6;
    
            listNode7.next = listNode8;
            listNode8.next = listNode4;
    
            ListNode result = getIntersectionNode(listNode1, listNode7);
            System.out.println(result.val);
        }
    
        public static ListNode getIntersectionNode(ListNode headA, ListNode headB) {
            int count1 = countList(headA);
            int count2 = countList(headB);
            int delta = Math.abs(count1 - count2);
            ListNode longer = count1 > count2 ? headA : headB;
            ListNode shorter = count1 > count2 ? headB : headA;
            ListNode node1 = longer;
            for (int i = 0; i < delta; i++) {
                node1 = node1.next;
            }
    
            ListNode node2 = shorter;
            while (node1 != node2) {
                node2 = node2.next;
                node1 = node1.next;
            }
    
            return node1;
        }
    
        private static int countList(ListNode head) {
            int count = 0;
            while (head != null) {
                count++;
                head = head.next;
            }
    
            return count;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
  • 相关阅读:
    2022 年全球十大最佳自动化测试工具
    CSS---div盒子模型、相对绝对位置、float浮动、清除浮动
    做点实事吧。
    如何在OpenWRT上安装SFTP并实现公网远程文件传输
    mysql5.7版本数据库主主同步
    Flow Problem(最大流模板)
    【React】第二部分 面向组件编程
    右键菜单添加 Open Git Bash
    python3.8,torch1.10.2+cu113、torch-geometric 安装
    并发的三大特性
  • 原文地址:https://blog.csdn.net/GoGleTech/article/details/133696102