Golang中Map按照Value大小排序的方法实例

目录
  • 起因
  • 探索
  • 实现
    • 第一步
    • 第二步
    • 第三步
  • 总结
  • 总结

Golang中的 map 默认是 无序的 。

起因

最近项目中有这样一个需求:

根据用户当前的坐标点,获取该用户附近的预设城市名称。

这里有一个注意点是,假设这些支持的城市名称是预设的,所以就不能直接通过地图类api根据坐标点获取所在城市名称了。

想到的解决思路是:

  1. 获取这几个预设城市的坐标点
  2. App端获取用户当前坐标点
  3. 分别计算得到该用户坐标点距离各个预设城市的坐标点距离
  4. 然后计算得到其中距离最小的一项
  5. 这个坐标点对应的城市就是所求

探索

经过前期计算,在上面的第 3 步操作后我得到了下面的结果:

result := map[string]float64{  
   "城市A": 2334.20,  
 "城市B": 1992.33,  
 "城市C": 500.26,  
 "城市D": 10.39,  
 "城市E": 333.33,  
}

我们知道,Golang中 Map 是 无序的 。所以当我们使用 for-range 循环时:

for k, v := range result {
   fmt.Printf("key: %v value: %v \n", k, v)
}

结果可能是:

// 第一种可能结果:
key: 城市B value: 1992.33 
key: 城市C value: 500.26 
key: 城市D value: 10.39 
key: 城市E value: 333.33 
key: 城市A value: 2334.2

// 第二种可能结果:
key: 城市E value: 333.33 
key: 城市A value: 2334.2 
key: 城市B value: 1992.33 
key: 城市C value: 500.26 
key: 城市D value: 10.39

// 第三种可能结果:
key: 城市E value: 333.33 
key: 城市A value: 2334.2 
key: 城市B value: 1992.33 
key: 城市C value: 500.26 
key: 城市D value: 10.39

所以,我们不能按照 key 或者 value 来进行排序。

实现

但Golang中切片 Slice 是 有序的。 我们可以结果使用 Slice 来实现对 Map 的排序。

第一步

我们先将上面的 map 转换成一个 slice :

type KVPair struct {
   Key string
 Val float64
}  

tmpList := make([]KVPair, 0)  

for k, v := range result {
   tmpList = append(tmpList, KVPair{Key: k, Val: v})
}

上面创建了一个 结构体切片 ,然后将 map 的值添加到切片中。

第二步

在 go1.8 之后,引入了 sort.Slice() 方法,可以实现对 slice 进行排序,我们只需要传入一个比较函数即可:

sort.Slice(tmpList, func(i, j int) bool {
   return tmpList[i].Val < tmpList[j].Val // 升序
})

第三步

然后,我们对排序后的 slice 进行 for-range 遍历:

for _, pair := range tmpList {  
   fmt.Printf("key: %v value: %v \n", pair.Key, pair.Val)  
}

// 结果:
key: 城市D value: 10.39 
key: 城市E value: 333.33 
key: 城市C value: 500.26 
key: 城市B value: 1992.33 
key: 城市A value: 2334.2

可以看到,排序后的 slice 第一项就是我们想要的结果。

如果我们想要获取其中 value 值最大的一项,只需要更改 sort.Slice 中的比较方法接口:

sort.Slice(tmpList, func(i, j int) bool {
   return tmpList[i].Val > tmpList[j].Val // 降序
 //return tmpList[i].Val < tmpList[j].Val // 升序})

总结

上面测试的完整代码如下:

package main  
  
import (  
   "fmt"  
 "sort")  
  
var result = map[string]float64{  
   "城市A": 2334.20,  
 "城市B": 1992.33,  
 "城市C": 500.26,  
 "城市D": 10.39,  
 "城市E": 333.33,  
}

func main() {

   type KVPair struct {  
      Key string  
      Val float64  
   }  
  
   tmpList := make([]KVPair, 0)  
  
   for k, v := range result {  
      tmpList = append(tmpList, KVPair{Key: k, Val: v})  
   }  
  
   sort.Slice(tmpList, func(i, j int) bool {  
      //return tmpList[i].Val > tmpList[j].Val // 降序  
      return tmpList[i].Val < tmpList[j].Val // 升序 
   })  
  
   for _, pair := range tmpList {  
      fmt.Printf("key: %v value: %v \n", pair.Key, pair.Val)  
   }  
}

总结

到此这篇关于Golang中Map按照Value大小排序的文章就介绍到这了,更多相关Golang中Map大小排序内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • golang 实现对Map进行键值自定义排序

    看代码吧~ //自定义结构体,用来自定义排序 type RecentlyUpdateListMapSorter []map[string]interface{} //根据MapSorter.Keys进行倒序排序 func (ms *RecentlyUpdateListMapSorter) SortReverse() { sort.Sort(sort.Reverse(ms)) } //自定义排序方法(Len(),Less(),Swap()) func (ms *RecentlyUpdateList

  • Golang中Map按照Value大小排序的方法实例

    目录 起因 探索 实现 第一步 第二步 第三步 总结 总结 Golang中的 map 默认是 无序的 . 起因 最近项目中有这样一个需求: 根据用户当前的坐标点,获取该用户附近的预设城市名称. 这里有一个注意点是,假设这些支持的城市名称是预设的,所以就不能直接通过地图类api根据坐标点获取所在城市名称了. 想到的解决思路是: 获取这几个预设城市的坐标点 App端获取用户当前坐标点 分别计算得到该用户坐标点距离各个预设城市的坐标点距离 然后计算得到其中距离最小的一项 这个坐标点对应的城市就是所求

  • java的Map集合中按value值进行排序输出的实例代码

    java的Map集合中按value值进行排序输出的实例代码 import java.util.Arrays; import java.util.Comparator; import java.util.HashMap; import java.util.Map; import java.util.Set; public class Test { public static void main(String[] args) { Map<String ,Integer> map = new Has

  • List集合对象中按照不同属性大小排序的实例

    实例如下: package com.huad.luck; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class Test { public static void main(String[] args) { Person p = new Person(); p.setName("tom"); p.

  • Python3将ipa包中的文件按大小排序

    给你个ipa包,解压前输出包大小,解压后把里面的文件按大小排序. 代码如下: import os import shutil import zipfile _ipa_zip_path = lambda ipa_path: ipa_path.replace('.ipa', '.zip') _file_size = lambda file_path: os.path.getsize(file_path) / 1024 / 1024 def unzip(zip_path: str) -> str: d

  • Golang中map数据类型的使用方法

    目录 前言 案例 map map定义 map声明 map的操作 总结 前言 今天咱们来学习一下golang中的map数据类型,单纯的总结一下基本语法和使用场景,也不具体深入底层.map类型是什么呢?做过PHP的,对于数组这种数据类型是一点也不陌生了.PHP中的数组分为索引数组和关联数组.例如下面的代码: // 索引数组[数组的key是一个数字, 从0,1,2开始递增] $array = [1, '张三', 12]; // 关联数组[数组的key是一个字符串,可以自定义key的名称] $array

  • Golang中map的深入探究

    目录 简介 Map 的底层内存模型 Map 的存与取 底层代码 Map 的扩容 第一种情况 第二种情况 Map 的有序性 Map 的并发 总结 简介 本文主要通过探究在golang 中map的数据结构及源码实现来学习和了解map的特性,共包含map的模型探究.存取.扩容等内容.欢迎大家共同讨论. Map 的底层内存模型 在 golang 的源码中表示 map 的底层 struct 是 hmap,其是 hashmap 的缩写 type hmap struct { // map中存入元素的个数, g

  • 关于golang中map使用的几点注意事项总结(强烈推荐!)

    目录 前言 1 使用 map 记得初始化 2 map 的遍历是无序的 3 map 也可以是二维的 4 获取 map 的 key 最好使用这种方式 5 map 是并发不安全的 ,sync.Map 才是安全的 总结 前言 日常的开发工作中,map 这个数据结构相信大家并不陌生,在 golang 里面,当然也有 map 这种类型 关于 map 的使用,还是有蛮多注意事项的,如果不清楚,这些事项,关键时候可能会踩坑,我们一起来演练一下吧 1 使用 map 记得初始化 写一个 demo 定义一个 map[

  • python中对数据进行各种排序的方法

    Python列表具有内置的 list.sort()方法,可以在原地修改列表. 还有一个 sorted()内置的函数从迭代构建一个新的排序列表.在本文中,我们将探讨使用Python排序数据的各种技术. 请注意,sort()原始数据被破坏,sorted()没有对原始数据进行操作,而是新建了一个新数据. 一.基本的排序 最基本的排序很简单.只要使用sorted()函数即可返回一个 新的排序的列表 >>>sorted([5, 2, 3, 1, 4]) [1, 2, 3, 4, 5] 咱们也可以使

  • Python实现字典排序、按照list中字典的某个key排序的方法示例

    本文实例讲述了Python实现字典排序.按照list中字典的某个key排序的方法.分享给大家供大家参考,具体如下: 1.给字典按照value按照从大到小排序 排序 dict = {'a':21, 'b':5, 'c':3, 'd':54, 'e':74, 'f':0} new_dict = sorted(dict.iteritems(), key=lambda d:d[1], reverse = True) print new_dict 输出: [('e', 74), ('d', 54), ('

  • Java中Map循环遍历的五种方法实现

    目录 1.创建一个Enum 2.开始遍历 方法一 方法二 方法三 方法四 方法五 因为Map比较常用,所以今天来总结下Map取值比较常用的几种遍历方法. 1.创建一个Enum public enum FactoryStatus {     BAD(0,"ou"),     GOOD(1,"yeah");     private int status;     private String description;     FactoryStatus(int stat

随机推荐