怎么利用求数组交集
发表于:2024-11-14 作者:千家信息网编辑
千家信息网最后更新 2024年11月14日,这篇文章给大家介绍怎么利用求数组交集,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。算法:求数组的交集,利用map的key,value特性会比较简单,步骤如下:1.先遍历数组1,然
千家信息网最后更新 2024年11月14日怎么利用求数组交集
这篇文章给大家介绍怎么利用求数组交集,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
算法:
求数组的交集,利用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安全错误
数据库的锁怎样保障安全
服务器装win10能用吗
企业网络安全培训哪家好
推服务器
java做数据库监控
网络安全保护法游戏
地籍数据库更新做法
宁波银行软件开发中心
重庆光学成像仿真软件开发
软件开发经费占比
网络技术课程授课创新点
服务器状态不好怎么修复
青少年网络安全口诀简短
如何删除服务器上的邮件
浙商银行银行软件开发待遇
武汉指飞扬网络技术有限公司
福建管理系统软件开发
数据库原理与技术淮海工学院
数学专业能为软件开发
网络安全手抄报筒单
在服务器怎么看小地图
万州区一站式软件开发流程特点
快递查询软件开发
哈尔滨秒房互联网科技有限公司
服务器的bug怎么修改
在数据库技术阶段 数据
oracle数据库的减集
产品信息数据库管理办法
建立网址数据库实验报告
企业网络安全防护方案
江苏润广宣网络技术有限公司