前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Golang数组去重&切片去重

Golang数组去重&切片去重

作者头像
美团骑手
发布2022-09-21 09:19:39
3.3K0
发布2022-09-21 09:19:39
举报
文章被收录于专栏:技术进阶技术进阶

合并两个整型切片,返回没有重复元素的切片,有两种去重策略

1. 通过双重循环来过滤重复元素(时间换空间)

// 通过两重循环过滤重复元素

代码语言:javascript
复制
func RemoveRepByLoop(slc []int) []int {
    result := []int{}  // 存放结果
    for i := range slc{
        flag := true
        for j := range result{
            if slc[i] == result[j] {
                flag = false  // 存在重复元素,标识为false
                break
            }
        }
        if flag {  // 标识为false,不添加进结果
            result = append(result, slc[i])
        }
    }
    return result
}

2. 通过字典来过滤(空间换时间)

// 通过map主键唯一的特性过滤重复元素

代码语言:javascript
复制
func RemoveRepByMap(slc []int) []int {
    result := []int{}
    tempMap := map[int]byte{}  // 存放不重复主键
    for _, e := range slc{
        l := len(tempMap)
        tempMap[e] = 0
        if len(tempMap) != l{  // 加入map后,map长度变化,则元素不重复
            result = append(result, e)
        }
    }
    return result
}

ps : 这里为了节省内存,使用map[int]byte。 因为map的value并没有用到,所以什么类型都可以。

效率第一,如果节省计算时间,则可以采用如下方式

// 元素去重

代码语言:javascript
复制
func RemoveRep(slc []int) []int{
    if len(slc) < 1024 {
        // 切片长度小于1024的时候,循环来过滤
        return RemoveRepByLoop(slc)
    }else{
        // 大于的时候,通过map来过滤
        return RemoveRepByMap(slc)
    }
}

ps: 1024 这个数字不是特别精准,我是使用go test 的基准测试,手工的比较的。大约在这个数量超上,使用map方式的速度要快,小于这个数量级后,loop方式要快,而且省内存。

原文:https://blog.csdn.net/qq_27068845/article/details/77407358

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-08-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 通过双重循环来过滤重复元素(时间换空间)
  • 2. 通过字典来过滤(空间换时间)
  • 效率第一,如果节省计算时间,则可以采用如下方式
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档