Leetcode-面试题 02.07 链表相交

作者: itbird01 | 来源:发表于2021-10-15 06:53 被阅读0次

面试题 02.07. 链表相交

解题思路

1.分析题意,两个链表时末尾相交,也就是说,只要知道两个链表从后往前最初的相等元素即可
2.求链表A的长度、 求链表B的长度
3.让curA为最长链表的头,lenA为其长度
4.求长度差,让curA和curB在同一起点上(末尾位置对齐)
5.遍历curA 和 curB,遇到相同则直接返回

解题遇到的问题

后续需要总结学习的知识点

能否设计一个时间复杂度 O(n) 、仅用 O(1) 内存的解决方案?

##解法
class Solution {
    public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
        ListNode curA = headA;
        ListNode curB = headB;
        int lenA = 0, lenB = 0;
        while (curA != null) { // 求链表A的长度
            lenA++;
            curA = curA.next;
        }
        while (curB != null) { // 求链表B的长度
            lenB++;
            curB = curB.next;
        }
        curA = headA;
        curB = headB;
        // 让curA为最长链表的头,lenA为其长度
        if (lenB > lenA) {
            // 1. swap (lenA, lenB);
            int tmpLen = lenA;
            lenA = lenB;
            lenB = tmpLen;
            // 2. swap (curA, curB);
            ListNode tmpNode = curA;
            curA = curB;
            curB = tmpNode;
        }
        // 求长度差
        int gap = lenA - lenB;
        // 让curA和curB在同一起点上(末尾位置对齐)
        while (gap-- > 0) {
            curA = curA.next;
        }
        // 遍历curA 和 curB,遇到相同则直接返回
        while (curA != null) {
            if (curA == curB) {
                return curA;
            }
            curA = curA.next;
            curB = curB.next;
        }
        return null;
    }

    public class ListNode {
        int val;
        ListNode next;
        ListNode(int x) {
            val = x;
        }
    }
}

相关文章

  • 面试题 02.07. 链表相交

    面试题 02.07. 链表相交[https://leetcode-cn.com/problems/intersec...

  • Leetcode-面试题 02.07 链表相交

    面试题 02.07. 链表相交[https://leetcode-cn.com/problems/intersec...

  • 链表--链表相交 leetcode面试题 02.07

    题目 给定两个链表,判断两个链表是否相交,如果相交返回相交的交点,否则返回空结点。 思路 暴破法采用双循环,从第一...

  • 1.数据结构-链表问题

    链表相关问题 删除节点 链表去重 有环链表 反转链表 链表排序 链表相交 其他问题 面试题 02.03. 删除中间...

  • 大厂面试系列(七):数据结构与算法等

    数据结构和算法 链表 链表,常见的面试题有写一个链表中删除一个节点的算法、单链表倒转、两个链表找相交的部分,这个一...

  • 链表--相交链表

    目录[https://www.jianshu.com/p/85e18c21317a] 题号[https://lee...

  • 链表相交的问题(java)

    判断两个无环链表是否相交首先我们要知道相交是什么概念两个链表相交.png现在大家都知道了,两个链表相交,则两个链表...

  • 相交链表

    编写一个程序,找到两个单链表相交的起始节点。 注意: 如果两个链表没有交点,返回 null.在返回结果后,两个链表...

  • 相交链表

    相交链表 编写一个程序,找到两个单链表相交的起始节点。 注意: 如果两个链表没有交点,返回 null. 在返回结果...

  • 相交链表

    题目 编写一个程序,找到两个单链表相交的起始节点。 例如,下面的两个链表: A: a1 → a2...

网友评论

    本文标题:Leetcode-面试题 02.07 链表相交

    本文链接:https://www.haomeiwen.com/subject/yjurnltx.html