Golang程序将数组中的元素按降序排序
在本教程中,我们将看到写一个go语言程序来对一个数组进行降序排序。在数学中,降序是指后面的元素比前面的元素小的顺序。
在这个例子中,我们将看到编写一个程序,使用用户定义的函数对一个整数阵列进行降序排序。
第1步 – 导入fmt软件包
第2步 – 定义一个函数sortDesc()来对给定数组进行排序。该函数接受一个参数,即我们希望进行排序的整数数组。
第3步 – 该函数使用两个for循环和if条件对数组进行排序。
第4步 – 使用第一个for循环遍历未排序的数组,第二个for循环获得数组中存在的最小值。
第5步 – 然后用一个临时变量把较小的数值放在较大的数值之后。
第6步 – 启动main()函数。
第7步 – 初始化一个整数数组并向其存储数值。在屏幕上打印未排序的数组。
第8步 – 然后我们需要调用sortDesc()函数,把要排序的数组作为参数传给该函数。
第9步 – 存储函数返回的数组并使用fmt.Println()函数将其打印在屏幕上。
下面的代码说明了我们如何用go编程语言对一个数组的元素进行降序排序。
package main
import "fmt"
func sortDesc(arr [5]int) [5]int {
for i := 0; i < len(arr); i++ {
for j := 1 + i; j < len(arr); j++ {
if arr[i] < arr[j] {
intermediate := arr[i]
arr[i] = arr[j]
arr[j] = intermediate
}
}
}
return arr
}
func main() {
arr := [5]int{50, 30, 20, 10, 40}
fmt.Println("The unsorted array entered is:", arr)
array := sortDesc(arr)
fmt.Println()
fmt.Println("The final array obtained after sorting is:", array)
}
The unsorted array entered is: [50 30 20 10 40]
The final array obtained after sorting is: [50 40 30 20 10]
下面的代码说明了在go编程语言中使用预定义的函数对一个整数数组进行降序排序。
sort.Sort(sort.Reverse(sort.IntSlice(arr)))
IntSlice()函数存在于排序包中,用于对一个整数数组进行排序。该函数接收一个未排序的整数数组,并通过排序返回数组。 Reverse()函数存在于排序包中。该函数接收要以反向顺序排序的数据作为参数,并通过反转其值返回数组的片断。
第1步 – 导入fmt和sort包。
第2步 – 启动main()函数。
第3步 – 初始化一个整数数组并向其存储数值。在屏幕上打印未排序的数组。
第4步 – 现在我们需要调用sort包中的Ints()函数,将需要排序的数组作为参数传给该函数。
第5步 – arr数组现在已经排序了。我们可以用fmt.Println()函数将其打印在屏幕上。
package main
import (
"fmt"
"sort"
)
func main() {
var arr = []int{9, 8, 7, 4, 5, 3}
fmt.Println("Unsorted array of strings is", arr)
sort.Sort(sort.Reverse(sort.IntSlice(arr)))
fmt.Println("The above array is sorted and the result is:", arr)
}
Unsorted array of strings is [9 8 7 4 5 3]
The above array is sorted and the result is: [9 8 7 5 4 3]
现在让我们写一个程序,使用go编程语言中的预定义函数对一个字符串数组进行降序排序。
sort.Sort(sort.Reverse(sort.StringSlice(arr)))
StringSlice()函数存在于sort包中,它接收要排序的字符串数组作为参数,并返回排序后的字符串。Reverse()函数存在于sort包中。该函数将待排序的数据作为一个参数,并通过反转其值返回数组的片断。
第1步 – 导入fmt和sort包。
第2步 – 启动main()函数。
第3步 – 初始化一个字符串数组,并向其存储数值。在屏幕上打印未排序的数组。
第4步 – 现在我们需要调用排序包中的StringSlice()函数,将需要排序的数组作为参数传给该函数。
第5步 – arr数组现在已经排序了。我们可以用fmt.Println()函数将其打印在屏幕上。
package main
import (
"fmt"
"sort"
)
func main() {
var arr = []string{"a", "b", "c", "d", "s"}
fmt.Println("Unsorted array of strings is", arr)
sort.Sort(sort.Reverse(sort.StringSlice(arr)))
fmt.Println("The above array is sorted and the result is:", arr)
}
Unsorted array of strings is [a b c d s]
The above array is sorted and the result is: [s d c b a]
我们已经成功地编译并执行了一个Go语言程序,将一个数组按降序排序,并附有实例。