LeetCode 160-相交链表

该博客介绍了解决LeetCode 160题——相交链表的方法。通过定义两个指针从各自链表的头部开始移动,经过一轮移动后,使指针长度差抹平。如果指针相遇,则找到了相交节点;若未相遇,则链表无交点。时间复杂度为O(m+n),空间复杂度为O(1)。
摘要由CSDN通过智能技术生成

给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。
题目数据保证整个链式结构中不存在环。
注意,函数返回结果后,链表必须保持其原始结构。

解题思路:

定义两个指针分别指向两个链表的头部, 首先让两个指针向后移动,让先移动到末尾的指针从另一个链表的头部再次移动,
最后如果相遇则为交点。
原理:在第一轮移动中恰好抹除了长度差,两个指针等于移动了相同的距离, 有交点就返回, 无交点就是各走了两条指针的长度。

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
    public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
    	// 1. 边界条件
        if(headA == null || headB == null) {
            return null;
        }
        // 2. 两个指针指向两个链表的头部
        ListNode head1 = headA;
        ListNode head2 = headB;
		// 3. 两个指针开始移动
		// 离开循环的条件:
		// 1.两个链表没有相交,两指针都会移动到末尾,head1 = head2 = null
		// 2.两个链表没有相交,head1 = head2 = 相交点
        while (head1 != head2) {
            if (head1 != null) {
                head1 = head1.next;
            } else {
                head1 = headB;
            }

            if (head2 != null) {
                head2 = head2.next;
            } else {
                head2 = headA;
            }
        }
        return head1;
    }
}

时间复杂度:O(m+n),其中 m 和 n 是两个链表的长度
空间复杂度:O(1)

如果对您有所帮助的话,请点个赞再退出吧!!!

题目链接:https://leetcode-cn.com/problems/intersection-of-two-linked-lists/添加链接描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值