go语言中实现slice去重的方法-创新互联
本文以go语言中的slice为例,为大家分析go语言中实现slice去重的方法。阅读完整文相信大家对go语言中实现slice去重的方法有了一定的认识。
成都创新互联-专业网站定制、快速模板网站建设、高性价比会同网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式会同网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖会同地区。费用合理售后完善,10年实体公司更值得信赖。合并两个整型slice,返回没有重复元素的切片,有两种去重策略
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并没有用到,所以什么类型都可以。
以上就是go语言中实现slice去重的方法介绍,详细使用情况还得要大家自己使用过才能知道具体要领。如果想阅读更多相关内容的文章,欢迎关注创新互联行业资讯频道!
当前题目:go语言中实现slice去重的方法-创新互联
文章路径:http://azwzsj.com/article/coscps.html