Golang✔️走进 Go 语言✔️ 第十四课 排序

Posted 我是小白呀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Golang✔️走进 Go 语言✔️ 第十四课 排序相关的知识,希望对你有一定的参考价值。

【Golang】✔️走进 Go 语言✔️ 第十四课 排序

概述

Golang 是一个跨平台的新生编程语言. 今天小白就带大家一起携手走进 Golang 的世界. (第 14 课)

sort

Go 语言的 sort 包实现了内置和用户定义类型的排序.

例 1:

package main

import (
	"fmt"
	"sort"
)

func main() {

	// 定义数组
	var array = []int{1, 5, 4, 6, 2, 3}
	fmt.Println(array)

	// 判断是否排序
	is_sort := sort.IntsAreSorted(array)
	fmt.Println("是否排序: ", is_sort)

	// 数组排序
	sort.Ints(array)
	fmt.Println(array)

	// 判断是否排序
	is_sort = sort.IntsAreSorted(array)
	fmt.Println("是否排序: ", is_sort)

}

输出结果:

[1 5 4 6 2 3]
是否排序:  false
[1 2 3 4 5 6]
是否排序:  true

例 2:

package main

import (
	"fmt"
	"sort"
)

func main() {

	// 定义数组
	var array = []string {"b", "a", "d", "c"}
	fmt.Println(array)

	// 判断是否排序
	is_sort := sort.StringsAreSorted(array)
	fmt.Println("是否排序: ", is_sort)

	// 数组排序
	sort.Strings(array)
	fmt.Println(array)

	// 判断是否排序
	is_sort = sort.StringsAreSorted(array)
	fmt.Println("是否排序: ", is_sort)

}

输出结果:

[b a d c]
是否排序:  false
[a b c d]
是否排序:  true

自定义排序

一个内置的排序算法需要有三个东西: 序列长度, 两个元素比较结果, 两个元素的交换方式.


根据字符串长短排序:

package main

import (
	"fmt"
	"sort"
)

type ByLength []string

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

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

func  (s ByLength) Less(i, j int) bool {
	return len(s[i]) < len(s[j])
}

func main() {

	// 定义数组
	var array = []string {"a", "ghij", "bc", "def"}
	
	// 排序
	sort.Strings(ByLength(array))

	// 调试输出
	fmt.Print(array)

}

输出结果:

[a bc def ghij]

以上是关于Golang✔️走进 Go 语言✔️ 第十四课 排序的主要内容,如果未能解决你的问题,请参考以下文章

Golang✔️走进 Go 语言✔️ 第二十四课 TCP 高阶操作

Golang✔️走进 Go 语言✔️ 第二十四课 TCP 高阶操作

Golang✔️走进 Go 语言✔️ 第四课 运算符

Golang✔️走进 Go 语言✔️ 第十一课 指针

Golang✔️走进 Go 语言✔️ 第十一课 指针

Golang✔️走进 Go 语言✔️ 第十课 数组