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;
    }
}
相关推荐
Yzzz-F3 小时前
CF GYM105316A DP
数据结构·算法
C雨后彩虹3 小时前
幼儿园分班
java·数据结构·算法·华为·面试
Yupureki3 小时前
《算法竞赛从入门到国奖》算法基础:入门篇-二分算法
c语言·开发语言·数据结构·c++·算法·visual studio
iAkuya3 小时前
(leetcode)力扣100 22相交链表(双指针)
算法·leetcode·链表
云技纵横4 小时前
Redis 数据结构底层与 Hash 优于 JSON 的工程实践
数据结构·redis·哈希算法
Binky6784 小时前
力扣--贪心篇(1)
数据结构·算法·leetcode
醉风塘4 小时前
数据库索引深度解析:从数据结构到最佳实践
数据结构·数据库
leaves falling4 小时前
数据结构-递归算法
数据结构
wanghowie4 小时前
01.09 Java基础篇|算法与数据结构实战
java·数据结构·算法