GO中对map排序的实现

 更新时间:2023年03月06日 10:11:06   作者:雨雨不怕雨  
本文主要介绍了GO中对map排序的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

GO语言中,map是哈希表,能够将特定类型的key映射到特定类型的Value上。在查询Map里面的内容时,其时间复杂度为O(1)非常高效。但其存储并不是线性的,遍历输出时,也没有顺序可言。如果需要按顺序的输出map中的元素,就需要借助其他数据结构的帮助。

按照需求,本文分别提供了按Key顺序输出map、按Value顺序输出map两种方法。

按Key顺序输出map

思路就是,先将key存储下来进行排序,然后按照排序后的顺序依次访问map,得到排序后的结果:

package main

import (
    "fmt"
    "sort"
)

func main() {
    m := make(map[int]int)
    m[2] = 5
    m[3] = 7
    m[1] = 6
    m[10] = 22
    m[8] = 9
    m[4] = 7
    fmt.Println("not sort:")
    for k, v := range m {
        fmt.Println(k, v)
    }
    // 得到key值
    var ks []int
    for k, _ := range m {
        ks = append(ks, k)
    }
    //对key排序
    sort.Ints(ks)
    //输出结果
    fmt.Println("sort:")
    for _, v := range ks {
        fmt.Println(v, m[v])
    }
}

按Value顺序输出map

思路就是,先将map中的值,存储到一个结构体中,然后将结构体实现Sort接口实现排序,再输出结果,代码如下:

package main

import (
    "fmt"
    "sort"
)

//定义结构体存放map值
type temp struct {
    k int
    v int
}
type temps []temp

//  实现sort包中Interface接口

func (t temps) Len() int {
    return len(t)
}

func (t temps) Less(i, j int) bool {
    return t[i].v < t[j].v
}

func (t temps) Swap(i, j int) {
    t[i], t[j] = t[j], t[i]
}

func main() {
    m := make(map[int]int)

    m[2] = 5
    m[3] = 7
    m[1] = 6
    m[10] = 22
    m[8] = 9
    m[4] = 7
    fmt.Println("not sort:")
    for k, v := range m {
        fmt.Println(k, v)
    }
    // 得到key值
    var ts temps
    for k, v := range m {
        ts = append(ts, temp{k: k, v: v})
    }
    //对key排序
    sort.Sort(ts)
    //输出结果
    fmt.Println("sort:")
    for _, v := range ts {
        fmt.Println(v.k, v.v)
    }

}

到此这篇关于GO中对map排序的实现的文章就介绍到这了,更多相关GO map排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 深入理解golang chan的使用

    深入理解golang chan的使用

    本文主要介绍了golang chan的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • Go 1.22版本新特性前瞻

    Go 1.22版本新特性前瞻

    这篇文章主要为大家介绍了Go 1.22版本新特性前瞻,包含语言的变化,编译器、运行时与工具链等应用对比详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01
  • go build 通过文件名后缀实现不同平台的条件编译操作

    go build 通过文件名后缀实现不同平台的条件编译操作

    这篇文章主要介绍了go build 通过文件名后缀实现不同平台的条件编译操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • golang gin 框架 异步同步 goroutine 并发操作

    golang gin 框架 异步同步 goroutine 并发操作

    这篇文章主要介绍了golang gin 框架 异步同步 goroutine 并发操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • go 打包运行文件在windows,liunx运行

    go 打包运行文件在windows,liunx运行

    这篇文章主要介绍了go 打包运行文件在windows,liunx运行的相关资料,需要的朋友可以参考下
    2023-11-11
  • golang 熔断器的实现过程

    golang 熔断器的实现过程

    这篇文章主要介绍了golang 熔断器的实现过程,Go 项目中使用熔断技术提高系统容错性。接下俩就来给打家介绍 go 熔断器和其使用,需要的朋友可以参考一下
    2022-01-01
  • Go语言库系列之flag的具体使用

    Go语言库系列之flag的具体使用

    这篇文章主要介绍了Go语言库系列之flag的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • Golang中time.After的使用理解与释放问题

    Golang中time.After的使用理解与释放问题

    这篇文章主要给大家介绍了关于Golang中time.After的使用理解与释放问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-08-08
  • go mod 依赖管理的具体使用

    go mod 依赖管理的具体使用

    在Go语言开发中,依赖管理是一项非常重要的工作,Go mod作为官方的包管理工具已经成为了Go语言依赖管理的首选方式,本文就来介绍一下go mod 依赖管理的具体使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • golang如何用type-switch判断interface变量的实际存储类型

    golang如何用type-switch判断interface变量的实际存储类型

    这篇文章主要介绍了golang如何用type-switch判断interface变量的实际存储类型,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04

最新评论