怎么利用求数组交集
发表于:2024-11-12 作者:千家信息网编辑
千家信息网最后更新 2024年11月12日,这篇文章给大家介绍怎么利用求数组交集,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。算法:求数组的交集,利用map的key,value特性会比较简单,步骤如下:1.先遍历数组1,然
千家信息网最后更新 2024年11月12日怎么利用求数组交集
这篇文章给大家介绍怎么利用求数组交集,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
算法:
求数组的交集,利用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安全错误
数据库的锁怎样保障安全
登录页面时服务器的连接被重置
数据库中check语法怎么用
苏州大学cuba数据库
CX5网卡在服务器安装卡槽
了解数据库(全面分析)
清理数据库碎片sql语句
500内服务器错误是怎么一回事
淘宝的服务器在哪里
05服务器是什么情况
工业有限网络技术
南京白鸥网络技术公司怎么样
java查数据库
p高级数据库技术
黑客网络技术服务
湖南新一代软件开发服务标准
万方等数据库打不开怎么回事
todesk能用代理服务器么
软件开发企业具体业务
数据库安全防范方法
安卓软件开发价钱是多少
asp sql数据库操作
北京运营网络技术服务单价
什么数据库数据全
学校网络安全法规
服务器进管理口
2006年前网络安全
三亚科技互联网招聘会
重庆大足食堂配送软件开发
c 如何连接数据库
部分员工网络安全意识不足