hot100 160.相交链表

思路:

1.算法流程:

(1)初始化两个指针:p = headA,q = headB。

(2)不断循环,直到p = q。

(3)每次循环,p和q各走一步。具体来说:如果p不是空节点,那么更新p为p.next,否则更新p为headB;如果q不是空节点,那么更新q为q.next,否则更新q为headA。

(4)循环结束时,如果两条链表相交,那么此时p和q都在相交的起始节点处,返回p;如果两条链表不相交,那么p和q都在空节点,所以也可以返回p,即空节点。

2.复杂度分析:

(1)时间复杂度:O(m + n),其中m是第一条链表的长度,n是第二条链表的长度。除了交点,每个节点都会被指针p访问至多一次,每个节点都会被指针q访问至多一次。

(2)空间复杂度:O(1)。

附代码:

java 复制代码
public class Solution {
    public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
        ListNode p = headA;
        ListNode q = headB;
        while(p != q){
            p = p != null ? p.next : headB;
            q = q != null ? q.next : headA;
        }
        return p;
    }
}
相关推荐
江南十四行9 分钟前
排序算法进阶:直接插入排序(简单排序)与希尔排序
数据结构·算法·排序算法
洛水水13 分钟前
【Redis入门】一篇详解Redis五大数据结构
数据结构·数据库·redis
CoderCodingNo16 分钟前
【CSP】CSP-J 2021真题 | 插入排序 luogu-P7910 (适合GESP四-六级及以上考生练习)
数据结构·算法·排序算法
努力努力再努力wz1 小时前
【MySQL进阶系列】一文打通事务机制:从锁、Undo Log 到 MVCC 与隔离级别
c语言·数据结构·数据库·c++·mysql·算法·github
薇茗1 小时前
【初阶数据结构】 左右逢源的分支诗律 二叉树1
c语言·数据结构·算法
澈2071 小时前
C++ string全面解析:从入门到精通
数据结构·c++·算法
Irissgwe2 小时前
算法之滑动窗口
数据结构·算法
纽扣6672 小时前
【算法进阶之路】链表核心:快慢指针与反转链表专题精讲
数据结构·c++·算法·链表
浅念-2 小时前
吃透栈:LeetCode 栈算法题全解析
数据结构·c++·算法·leetcode·职场和发展·
承渊政道2 小时前
【动态规划算法】(两个数组的DP问题深度剖析与求解方法)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法