文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么在golang中对slice元素去重

2023-06-14 22:45

关注

怎么在golang中对slice元素去重?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

什么是golang

golang 是Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言,其语法与 C语言相近,但并不包括如枚举、异常处理、继承、泛型、断言、虚函数等功能。

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

// 通过两重循环过滤重复元素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主键唯一的特性过滤重复元素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并没有用到,所以什么类型都可以。

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

// 元素去重func RemoveRep(slc []int) []int{    if len(slc) < 1024 {        // 切片长度小于1024的时候,循环来过滤        return RemoveRepByLoop(slc)    }else{        // 大于的时候,通过map来过滤        return RemoveRepByMap(slc)    }}

ps:1024 这个数字不是特别精准,我是使用go test 的基准测试,手工的比较的。

大约在这个数量超上,使用map方式的速度要快,小于这个数量级后,loop方式要快,而且省内存。

补充:Golang数组去重&切片去重

方法一:

定义一个新切片(数组),存放原数组的第一个元素,然后将新切片(数组)与原切片(数组)的元素一一对比,如果不同则存放在新切片(数组)中。

package mainimport "fmt"func main() {    var arr = []string{"hello", "hi", "world", "hi", "china", "hello", "hi"}    fmt.Println(RemoveRepeatedElement(arr))}func RemoveRepeatedElement(arr []string) (newArr []string) {    newArr = make([]string, 0)    for i := 0; i < len(arr); i++ {        repeat := false        for j := i + 1; j < len(arr); j++ {            if arr[i] == arr[j] {                repeat = true                break            }        }        if !repeat {            newArr = append(newArr, arr[i])        }    }    return}

方法二:

先将原切片(数组)进行排序,在将相邻的元素进行比较,如果不同则存放在新切片(数组)中。

package mainimport "fmt"func main() {    var arr = []string{"hello", "hi", "world", "hi", "china", "hello", "hi"}    fmt.Println(RemoveRepeatedElement(arr))}func RemoveRepeatedElement(arr []string) (newArr []string) {    newArr = make([]string, 0)    sort.Strings(arr)    for i := 0; i < len(arr); i++ {        repeat := false        for j := i + 1; j < len(arr); j++ {            if arr[i] == arr[j] {                repeat = true                break            }        }        if !repeat {            newArr = append(newArr, arr[i])        }    }    return}

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网行业资讯频道,感谢您对编程网的支持。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯