【d44】【Java】【力扣】160.相交链表

思路

先把a链表都放进 一个hashSet集合

再遍历B链表,逐个放进hashSet集合

如果无法放进,说明这个节点就是相交节点

代码

复制代码
import java.util.HashSet;

public class Main {
    public static void main(String[] args) {

    }

   public class ListNode {
       int val;
       ListNode next;
       ListNode(int x) {
           val = x;
           next = null;
       }
   }

    public class Solution {
        public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
            //遍历A链表,并都放入hashSet中
            ListNode cur = headA;
            HashSet<ListNode> hashSet = new HashSet<>();
            //每一个都添加到一个hasSet中
            while (cur != null) {
                hashSet.add(cur);
                cur = cur.next;
            }
            //cur指向头部
            //遍历b,如果放不进,说明遇到相交节点
            cur=headB;
            while (cur != null) {
                if(!hashSet.add(cur)){
                    return cur;
                }
            }
            return null;
        }
    }


}

记录

总结

相关推荐
海棠AI实验室2 分钟前
Python 学习路线图:从 0 到 1 的最短闭环
开发语言·python·学习
不会聊天真君6474 分钟前
设计模式、线程状态、上下文切换、线程安全(JAVA并发第二期)
java
Macbethad5 分钟前
技术报告:加密算法实现与性能优化研究
开发语言
玄同7656 分钟前
Python 函数:LLM 通用逻辑的封装与复用
开发语言·人工智能·python·深度学习·语言模型·自然语言处理
Swift社区6 分钟前
死锁:线程卡死不是偶然,而是设计问题
java·spring·maven
uup6 分钟前
防止短信验证码接口被盗刷问题
java
lkbhua莱克瓦2411 分钟前
基础-事务
开发语言·数据库·笔记·mysql·事务
xxxmine13 分钟前
ConcurrentHashMap 和 Hashtable 的区别详解
java·开发语言
凛_Lin~~13 分钟前
安卓 面试八股文整理(原理与性能篇)
android·java·面试·安卓
阿猿收手吧!20 分钟前
【C++】brpc与grpc对比
开发语言·c++