首页 > 其他分享 >按照结构体的某个字段排序

按照结构体的某个字段排序

时间:2022-09-30 15:02:06浏览次数:46  
标签:sort 10 12 int Persons func 某个 排序 按照

 问题

type TFault1 struct {     New        int32     Closed     int32 }

http-json接口返回后

{“Closed”:123,"New":456}

希望返回

{“New”123,"Closed":456}

 

 

golang的sort包默认支持int, float64, string的从小大到排序:
int -> Ints(x []int)
float64 -> Float64s(x []float64)
string -> Strings(x []string)

同时它还提供了自定义的排序接口Interface,此接口保护三个方法。

type Interface interface {
// Len is the number of elements in the collection.
Len() int
// Less reports whether the element with
// index i should sort before the element with index j.
Less(i, j int) bool
// Swap swaps the elements with indexes i and j.
Swap(i, j int)
}
 
golang默认提供了三个类型,他们都实现了Interface:
Float64Slice
IntSlice
StringSlice

从大到小排序
方法1:先使用提供的从大到小排序,再翻转

arr := []float64{0.1, 0.5, 0.8, 0.4, 0.2}

sort.Sort(sort.Reverse(sort.Float64Slice(arr)))
fmt.Println(arr) // [0.8 0.5 0.4 0.2 0.1]

 
方法二:自定义类型实现

type Float64SliceDecrement []float64

func (s Float64SliceDecrement) Len() int { return len(s) }

func (s Float64SliceDecrement) Swap(i, j int) { s[i], s[j] = s[j], s[i] }

func (s Float64SliceDecrement) Less(i, j int) bool { return s[i] > s[j] }

func main() {
arr := []float64{0.1, 0.5, 0.8, 0.4, 0.2}

sort.Sort(Float64SliceDecrement(arr))
fmt.Println(arr) // [0.8 0.5 0.4 0.2 0.1]

按照结构体的某个字段排序
按年纪从大到小排序

type Persons struct {
Age int
Height int
}

type PersonsSliceDecrement []Persons

func (s PersonsSliceDecrement) Len() int { return len(s) }

func (s PersonsSliceDecrement) Swap(i, j int) { s[i], s[j] = s[j], s[i] }

func (s PersonsSliceDecrement) Less(i, j int) bool { return s[i].Age > s[j].Age }

func main() {
arr1 := []Persons{
Persons{10, 12},
Persons{20, 12},
Persons{9, 12},
Persons{10, 12},
Persons{11, 12},
}
sort.Sort(PersonsSliceDecrement(arr1))
fmt.Println(arr1)
}

 

[{20 12} {11 12} {10 12} {10 12} {9 12}]
1
按年纪从大到小,如果年纪相等的,按身高从小到到

type Persons struct {
Age int
Height int
}

type PersonsSliceDecrement []Persons

func (s PersonsSliceDecrement) Len() int { return len(s) }

func (s PersonsSliceDecrement) Swap(i, j int) { s[i], s[j] = s[j], s[i] }

func (s PersonsSliceDecrement) Less(i, j int) bool {
if s[i].Age > s[j].Age {
return true
}
if s[i].Age == s[j].Age && s[i].Height < s[j].Height {
return true
}

return false
}

func main() {
arr1 := []Persons{
Persons{10, 120},
Persons{20, 12},
Persons{10, 110},
Persons{10, 11},
Persons{10, 100},
}
sort.Sort(PersonsSliceDecrement(arr1))
fmt.Println(arr1)
}
 

[{20 12} {10 11} {10 100} {10 110} {10 120}]
1
使用 sort.Stable 进行稳定排序
sort.Sort 并不保证排序的稳定性。如果有需要, 可以使用 sort.Stable ,用法就是将sort.Sort 替换为 sort.Stable 

 

 

搜索

复制

标签:sort,10,12,int,Persons,func,某个,排序,按照
From: https://www.cnblogs.com/rsapaper/p/16744910.html

相关文章

  • SQL之排序检索数据
     ORDERBY子句必须是SELECT语句中最后一条子句1、排序数据1select2col_name3from4table_name5orderby6col_name;2、按多个列排序1select2col_name,......
  • 找朋友(插入排序青春版)
    找朋友(插入排序青春版)[(https://www.online1987.com/找朋友/)]#include<iostream>#include<vector>usingnamespacestd;intmain(){ intN=0; cin>>N; vect......
  • 快速排序
    #include<iostream>#include<algorithm>#include<ctime>#include<cstdlib>usingnamespacestd;constintMAXN=100005;inta[MAXN],n;voidsort(intl,intr){......
  • 实体验证--根据某个字段判断另一字段是否必填
    ///<summary>///根据传入属性字段决定是否需要必填字段///</summary>[AttributeUsage(AttributeTargets.Property|AttributeTargets.Field,AllowMul......
  • sql排序函数 rank() / dense_rank()
    Rank排名函数1、rank()按照某字段的排序结果添加排名,但是他是跳跃的、间断的排名partitionby子句按照对应字段将结果集分为多个分区,然后orderby子句按分数对结果集进......
  • 【排序】快速排序C++实现总结
    一、算法步骤快速排序的基本思想是:1.先从数列中取出一个数作为基准数。2.分区过程,将比这个数大的数全放到它的右边,小于或等于它的数全放到它的左边。3.再对左右区间重复第二步,......
  • Python实现列表中嵌套字典按照给定key值去重
    需求:对下列数据按任意字段去重需要达到的效果:按照id进行去重,id重复则算重复。重复的取第一个数据。按照name和tel去重,name和tel都重复则算重复。重复的取第一个数据。......
  • JavaScript排序 — sort()方法(解决null、undefined、0之间的排序(混乱)问题)
    JavaScript排序—sort()方法——解决null、undefined、0之间的排序(混乱)问题一、普通的数组排序​ JavaScript中用方法sort()为数组排序。sort()方法有一个可选参数,是......
  • 归并排序(merge sort):细节,注意事项
    如果在某一个程序中要多次使用归并排序,最好将在排序中要使用的tmp数组定义在排序函数之外,将tmp作为归并排序方法的一个参数,而不是在归并排序中每次新定义一个tmp数组,因......
  • Redis:HGETALL的排序问题
    HGETALL介绍Returnsallfieldsandvaluesofthehashstoredatkey.Inthereturnedvalue,everyfieldnameisfollowedbyitsvalue,sothelengthofthere......