怎么利用求数组交集
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,这篇文章给大家介绍怎么利用求数组交集,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。算法:求数组的交集,利用map的key,value特性会比较简单,步骤如下:1.先遍历数组1,然
千家信息网最后更新 2025年12月02日怎么利用求数组交集
这篇文章给大家介绍怎么利用求数组交集,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
算法:
求数组的交集,利用map的key,value特性会比较简单,步骤如下:
1.先遍历数组1,然后将数组存到map1中2.遍历数组2,将数组存入map2中,存的过程中需要判断是否存在与map1中,根据题目要求做去重处理或者不去重处理。3.将满足条件的元素放到新的数组里面。(备注:如果是多个数组的话,可以两两求交集,然后依次递减,直到数组个数为1.)
题目1:

代码实现:
func intersection(nums1 []int, nums2 []int) []int { var numMap,numMap1 map[int]bool var tar []int numMap =make(map[int]bool) numMap1 =make(map[int]bool) for _,i:=range nums1 { // 遍历数组1排除重复的数字 if _,v:=numMap[i];!v { numMap[i] = true } } for _,j:=range nums2 { if _,v:=numMap1[j];!v { // 遍历数组2排除重复的数字 if _,v1:=numMap[j];v1{ // 求数组1和数组2的交集 numMap1[j] = true tar = append(tar,j) } } } return tar}执行结果:
题目2:
https://leetcode-cn.com/problems/intersection-of-two-arrays-ii/

代码实现:
func intersect(nums1 []int, nums2 []int) []int { if len(nums1) == 0 || len(nums2) == 0 { return nil } var tar []int nMap := make(map[int]int) for _,n := range nums1 { _, ok := nMap[n] if !ok { nMap[n] = 1 } else { nMap[n]++ } } for _, m := range nums2 { _, ok := nMap[m] if ok && nMap[m]>0{ nMap[m]-- tar = append(tar,m) } } return tar }执行结果:
关于怎么利用求数组交集就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
数组
交集
题目
代码
内容
数字
更多
结果
处理
帮助
不错
个数
元素
兴趣
备注
多个
小伙
小伙伴
文章
条件
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
服务器风扇外电控制
xampp的数据库可以删除吗
全省学生网络安全答题活动
网络安全行政级别保护制度时
携程的网络安全问题
分布式数据库查询优化算法
下面的不是数据库技术特点
国家大数据服务器 临沂
铜梁区媒体网络技术活动简介
mysql数据库目录怎么设置
网络安全遴选真题
世界网络安全公司实力排名
大话2怎么查可移民服务器
网页如何从数据库中提取照片
手机软件开发版是什么
查询数据库中字段
Ocean服务器
数据库表没大写
expdp数据库版本不一致
大班网络安全知识教案
正规软件开发应用
河北职业软件开发java
软件开发技术方案评审流程
郑州好好干网络技术有限公司
前端后端和数据库视频
提升网络安全意识心得
xp远程远程服务器
怎么查网站服务器在哪里租赁
awsali数据库架构
创一网络技术有限公司