GolangNote

Golang笔记

Golang 切片的快速排序

Permalink

下面是一个 Golang 对切片的快速排序的例子,排序的对象是slice int 类型。

Golang 切片的快速排序

Go: 切片快速排序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
package main

import (
    "fmt"
)

func QSort(arr []int, start int, end int) {
    var (
        key  int = arr[start]
        low  int = start
        high int = end
    )
    for {
        for low < high {
            if arr[high] < key {
                arr[low] = arr[high]
                break
            }
            high--
        }
        for low < high {
            if arr[low] > key {
                arr[high] = arr[low]
                break
            }
            low++
        }
        if low >= high {
            arr[low] = key
            break
        }
    }
    if low-1 > start {
        QSort(arr, start, low-1)
    }
    if high+1 < end {
        QSort(arr, high+1, end)
    }
}

func main() {
    arr := []int{5, 1, 3, 0, 9, 8, 7, 4, 6}
    fmt.Println(arr)
    QSort(arr, 0, len(arr)-1)
    fmt.Println(arr)
}

输出:

plaintext: 排序输出
1
2
[5 1 3 0 9 8 7 4 6]
[0 1 3 4 5 6 7 8 9]

本文网址: https://golangnote.com/topic/32.html 转摘请注明来源

Related articles

Golang quicktemplate 模版快速入门

Golang 有很多的模版引擎,自带的 `html/template` 也很好,大多数情况都能满足需求,只是有些逻辑、条件判断不好在模版里实现, `quicktemplate` 是个很好的选择。...

Golang phantomjs 动态代理实现

phantomjs 是个很优秀的软件,虽然现在被chrome headless 抢了风头,但在某些特定场合,使用phantomjs 还是很方便,这里是介绍使用Go 实现动态代理。...

golang共享数据用Mutex 或 Channel

在go 里,多线程对共享数据的操作一般要使用Mutex 或 Channel 来加锁或隔离通信。下面是一个使用Mutex 和 Channel 比较的例子。...

Golang 实现 10 进制转 N 进制

给定一个不没有重复字符的字符串,如 `[0-9,a-z]`,把一个 10 进制数字转为,该字符集的字符串。应用场合如汽车牌、顺序计数。...

Write a Comment to "Golang 切片的快速排序"

Submit Comment Login
Based on Golang + fastHTTP + sdb | go1.22.3 Processed in 0ms