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;
    }
}
相关推荐
Hello World . .18 分钟前
排序算法:常用排序算法
c语言·数据结构·算法·vim·排序算法
虢薪33 分钟前
双向链表与循环链表基础操作&进阶操作
数据结构·链表
寄存器漫游者34 分钟前
数据结构 单向链表进阶
数据结构·链表
秋深枫叶红41 分钟前
嵌入式C语言阶段复习——函数
c语言·数据结构·算法
生命不息战斗不止(王子晗)1 小时前
2026面试大纲 - java数据结构与集合专题
java·数据结构·面试
青桔柠薯片1 小时前
数据结构:排序与算法
数据结构·排序算法
执着2591 小时前
力扣hot100 - 226、翻转二叉树
数据结构·算法·leetcode
-Try hard-1 小时前
排序和查找算法:插入排序、希尔排序、快速排序以及二分查找
数据结构·算法·排序算法
鲨辣椒100861 小时前
算法也能降低时间复杂度???—————算法延伸
数据结构·算法·排序算法
嵌入小生0071 小时前
数据结构 | 常用排序算法大全及二分查找
linux·数据结构·算法·vim·排序算法·嵌入式