go语言结构体排序

简言

1.  go语言的基本数据类型可以直接调用sort()函数进行排序

2.  结构体的排序需要实现三个函数(获取长度函数,交换函数,比较函数)即可

实验如下图

源代码如下

package main
import (
	"fmt"
	"sort"
)

// 学生信息
type Student struct {
	Age   int
	Score int
}

// 结构体数组
type Students []*Student
// 下面的三个函数必须实现(获取长度函数,交换函数,比较函数(这里比较的是年龄))
func (s Students) Len() int {
	return len(s)
}
func (s Students) Swap(i, j int) {
	s[i], s[j] = s[j], s[i]
}
func (s Students) Less(i, j int) bool {
	return s[i].Age < s[j].Age
}

func main() {
	// 新建3个学生信息,这里特意用指针,表示指针也没问题;当然直接用结构体也是可以的
	Data := []*Student{}
	Data = append(Data, &Student{Age: 10, Score: 100})
	Data = append(Data, &Student{Age: 9, Score: 90})
	Data = append(Data, &Student{Age: 11, Score: 110})

	sort.Sort(sort.Reverse(Students(Data)))
	fmt.Printf("根据年龄从大到小排序 \n")
	for i := 0; i < len(Data); i++ {
		fmt.Printf("第%v个学生%+v \n", i, Data[i])
	}

	sort.Sort(Students(Data))
	fmt.Printf("\n根据年龄从小到大排序 \n")
	for i := 0; i < len(Data); i++ {
		fmt.Printf("第%v个学生%+v \n", i, Data[i])
	}
}

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值