NC313 两个数组的交集

文章目录

一、读题

题目来源:https://www.nowcoder.com/practice/56ea71d1f4e94de2aaec10e985874cce?tpId=0\&difficulty=\&judgeStatus=\&tags=\&title=两个数组的\&sourceUrl=\&gioEnter=menu

    题目的意思很简单,就是求两个数组的交集,和求链表的共同数据基本相同

二、思路

    思路很简单,遍历两个数组,将相同的数据取出来即可,可以通过hash表来实现,遍历第一个数组的时候将每个数都加入到hash表当中,在遍历第二个数组的时候就进行判断,如果这个数据已经在hash表当中存在,那么说明这个数据是交集数据,那么就直接添加到ArrayList当中

实现细节

    这道题有坑,如果只是单独的进行判断是否存在而不做其他处理的话,会导致结果错误

    仔细分析,假设先遍历第一个数组,那么1 2 3会被添加到hash表,没有问题,问题出现在遍历第二个数组,当遍历到第一个2 的时候,我们发现hash表当中已经存在2了,那么说明2是公共数据添加到ArrayLiist,再往后遍历发现还是2,这个时候又将2添加到ArrayLiist当中,这个时候问题就呈现出来了,ArrayLiist里面会出现重复的数据,这是不对的

    解决办法也很简单,当我们添加一个元素进入ArrayLiist的时候,我们就将该元素从hash表当中删除,这样就再也不会判断到该元素了

实现细节

    有一个优化的空间,我们可以不使用hash表进行判断数据是否存在,我们可以创建一个boolean类型的数组,遍历数据的时候就将对应数组下标设置为true,表示当前下标的数据出现了,这样子可以节省hash表的导入时间以及hash值得计算,对于小范围数据,使用数组模拟哈希表确实比创建HashMap更高效,booolean类型的数组的范围可以用数据的最大值+10,只要大于数据的最大值即可

三、代码实现:

sql 复制代码
import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param nums1 int整型ArrayList 
     * @param nums2 int整型ArrayList 
     * @return int整型ArrayList
     */
    public ArrayList<Integer> intersection (ArrayList<Integer> nums1, ArrayList<Integer> nums2) {
        //通过hash表来进行判断是否重复出现某个数据 ,对于小范围数据,使用数组模拟哈希表确实比创建HashMap更高效,因此可以通过一个boolean类型的数组模拟hash表
        //boolean默认是false
        boolean[] ans = new boolean[1000 + 10];
        ArrayList<Integer> list = new ArrayList<>();

        for(Integer i : nums1) {
            ans[i] = true;
        }

        for(Integer i : nums2) {
            if(ans[i]) {
                list.add(i);
                ans[i] = false;
            }
        }

        return list;
    }
}

    各位佬,如果有什么更加高效的算法欢迎评论区讨论,指导一下主包进步,大家一起共勉

相关推荐
muddjsv1 分钟前
《算法导论》入门学习路径:从零基础到系统掌握
学习·算法
KaMeidebaby19 分钟前
卡梅德生物技术快报|组蛋白乙酰化修饰调控动脉粥样硬化的分子机制及中药表观干预研究
网络·人工智能·网络协议·tcp/ip·算法
Fms_Sa19 分钟前
分治法—最大子段问题
算法·c#
Galerkin码农选手24 分钟前
awq_marlin和gptq_marlin量化算法简要介绍
算法
buhuizhiyuci25 分钟前
【算法篇】动态规划——斐波那契数列模型
算法·动态规划
棱镜研途26 分钟前
学习笔记丨模式识别与机器学习5大核心赛道解析(IC-IPPR 2026)
人工智能·神经网络·算法·机器学习·模式识别·学术会议·智能计算
SuperHeroWu736 分钟前
【算法】逻辑回归虽然名字中有“回归“,但通常用于二分类任务。如何理解学习?
算法·回归·逻辑回归·二分类任务
gCode Teacher 格码致知40 分钟前
Python教学:十六进制编码的显示方法-由Deepseek产生
开发语言·python·算法
05候补工程师40 分钟前
【408数据结构】核心考点:图(Graph)精炼笔记与算法直觉
数据结构·经验分享·笔记·考研·算法·图论
靠沿41 分钟前
【动态规划算法】专题三——简单多状态dp问题
算法·动态规划