LeetCode 刷题【160. 相交链表】

160. 相交链表

自己做

解:快慢指针

java 复制代码
/**
 * 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) {
        int len1 = 0;
        int len2 = 0;
        ListNode p = headA;
        ListNode q = headB;
        
        while(p != null){
            len1++;
            p = p.next;
        }

        while(q != null){
            len2++;
            q = q.next;
        }

        p = headA;
        q = headB;

        if(len1 < len2)
            for(int i = 0; i < len2 - len1; i++)
                q = q.next;
        else
            for(int i = 0; i < len1 - len2; i++)
                p = p.next;

        while(p != null && q != null && p != q){
            p = p.next;
            q = q.next;
        }        

        if(p == q)
            return p;
        else
            return null;
    }
}
相关推荐
散峰而望2 分钟前
【算法竞赛】C++函数详解:从定义、调用到高级用法
c语言·开发语言·数据结构·c++·算法·github
CoderCodingNo12 分钟前
【GESP】C++五级真题(贪心思想考点) luogu-B4071 [GESP202412 五级] 武器强化
开发语言·c++·算法
我有一些感想……18 分钟前
An abstract way to solve Luogu P1001
c++·算法·ai·洛谷·mlp
前端小L19 分钟前
双指针专题(三):去重的艺术——「三数之和」
javascript·算法·双指针与滑动窗口
在风中的意志23 分钟前
[数据库SQL] [leetcode] 2388. 将表中的空值更改为前一个值
数据库·sql·leetcode
智者知已应修善业1 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
还不秃顶的计科生2 小时前
LeetCode 热题 100第二题:字母易位词分组python版本
linux·python·leetcode
LYFlied2 小时前
【每日算法】LeetCode 416. 分割等和子集(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
多米Domi0112 小时前
0x3f 第19天 javase黑马81-87 ,三更1-23 hot100子串
python·算法·leetcode·散列表
历程里程碑2 小时前
滑动窗口最大值:单调队列高效解法
数据结构·算法·leetcode