怎么利用求数组交集
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章给大家介绍怎么利用求数组交集,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。算法:求数组的交集,利用map的key,value特性会比较简单,步骤如下:1.先遍历数组1,然
千家信息网最后更新 2025年02月03日怎么利用求数组交集
这篇文章给大家介绍怎么利用求数组交集,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
算法:
求数组的交集,利用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安全错误
数据库的锁怎样保障安全
网络安全知识说说
角色是数据库管理系统
命令行改数据库
数据库没错为啥登录不进去
新源县网络安全通知
黄浦区新型网络技术有哪些
关系数据库中关键帧
数据库改ip地址
软件开发计划书 大学生
国药控股自有软件开发公司
我的世界国际基岩版怎么开服务器
计算机网络技术的职业需求
西城区专业性网络技术推广系统
服务器cpu出问题怎么办
南开区网络安全王丽红
如何做一个数据计算软件开发
服务器主板用内存还是cpu
bim数据库使用优势
数据库软件做一个多少钱
新时代的网络及网络安全
企业家有道网络技术
为什么联想服务器进不去系统设置
数据库中检索
厦门起点生活网络技术有限公司
1069数据库
特斯拉 软件开发团队
hcml的服务器ip
组态王数据库数据查询
腾讯云MySQL数据库三年
小型互联网科技公司怎么赚钱