2025年--Lc231-350. 两个数组的交集 II-Java版

1.题目

2.思路

3.代码实现

java 复制代码
class Solution {
    public int[] intersect(int[] nums1, int[] nums2) {
// 统计频率:用哈希表记录 nums1 中每个元素的出现次数。
// 动态匹配:遍历 nums2,若元素在哈希表中且剩余次数 > 0,则加入结果,并减少哈希表中的计数。
// 优化空间:为了节省内存,选择较短的数组作为哈希表的统计对象
   if(nums1.length>nums2.length)
   {
    // 保证 nums1 是较短的数组,减少哈希表空间
    return intersect(nums2,nums1);
   }
   HashMap<Integer,Integer> ma=new HashMap<>();
   //统计nums1中元素的频率
   for(int num:nums1)
   {//ma存放元素和元素出现的次数
    ma.put(num,ma.getOrDefault(num,0)+1);
   } 
   List<Integer> res=new ArrayList<>();   
   // 遍历 nums2,动态匹配并减少计数
   for(int num:nums2) 
   {
    int cnt=ma.getOrDefault(num,0);
    if(cnt>0)
    {
        res.add(num);
        ma.put(num,cnt-1);
    }
   }
   //转换成数组
   int[] ans=new int[res.size()];
   for(int i=0;i<ans.length;i++)
   {
    ans[i]=res.get(i);
   }
   return ans;
    
}
}
相关推荐
爱装代码的小瓶子3 小时前
【c++进阶】从C++98到C++11的奇妙旅程(故事科普版)
开发语言·c++
智航GIS3 小时前
2.3 运算符详解
开发语言·python
web3.08889993 小时前
接入API-自动化批量获取淘宝商品详情数据
开发语言·python
世转神风-4 小时前
qt-在字符串中指定位置插入字符串
开发语言·qt
驱动探索者4 小时前
[缩略语大全]之[内存管理]篇
java·网络·算法·内存管理
时光呀时光慢慢走4 小时前
C# WinForms 实战:MQTTS 客户端开发(与 STM32 设备通信)
开发语言·c#
okseekw4 小时前
Java反射:解锁框架开发的终极密码,让代码拥有"动态灵魂"!
java·后端
码农水水4 小时前
腾讯Java面试被问:阻塞队列BlockingQueue的实现原理
java·后端·python·面试
superman超哥4 小时前
仓颉类型别名的使用方法深度解析
c语言·开发语言·c++·python·仓颉
廋到被风吹走4 小时前
【Spring】BeanPostProcessor详解
java·后端·spring