当前位置: 首页 > article >正文

go语言种的常用排序方法

go语言种的常用排序方法

Go语言中常用的排序方法有以下几种:

  1. 冒泡排序(Bubble Sort)
func BubbleSort(arr []int) []int {
    n := len(arr)
    for i := 0; i < n-1; i++ {
        for j := 0; j < n-i-1; j++ {
            if arr[j] > arr[j+1] {
                arr[j], arr[j+1] = arr[j+1], arr[j]
            }
        }
    }
    return arr
}
  1. 插入排序(Insertion Sort)
func InsertionSort(arr []int) []int {
    n := len(arr)
    for i := 1; i < n; i++ {
        key := arr[i]
        j := i - 1
        for j >= 0 && arr[j] > key {
            arr[j+1] = arr[j]
            j--
        }
        arr[j+1] = key
    }
    return arr
}
  1. 选择排序(Selection Sort)
func SelectionSort(arr []int) []int {
    n := len(arr)
    for i := 0; i < n-1; i++ {
        minIndex := i
        for j := i + 1; j < n; j++ {
            if arr[j] < arr[minIndex] {
                minIndex = j
            }
        }
        arr[i], arr[minIndex] = arr[minIndex], arr[i]
    }
    return arr
}
  1. 快速排序(Quick Sort)
func QuickSort(arr []int) []int {
    if len(arr) <= 1 {
        return arr
    }
    pivot := arr[0]
    var less, greater []int
    for _, num := range arr[1:] {
        if num <= pivot {
            less = append(less, num)
        } else {
            greater = append(greater, num)
        }
    }
    var sorted []int
    sorted = append(sorted, QuickSort(less)...)
    sorted = append(sorted, pivot)
    sorted = append(sorted, QuickSort(greater)...)
    return sorted
}

以上是一些常用的排序方法,你可以根据需要选择适合的方法来对切片进行排序。


http://www.kler.cn/news/331690.html

相关文章:

  • 力扣(leetcode)每日一题 699 掉落的方块 | 线段树|经典
  • MFC工控项目实例二十一型号选择界面删除参数按钮禁用切换
  • Python知识点:如何使用TensorFlow Lite与Python进行边缘AI计算
  • 【网络】网络安全概述
  • 探索未来:mosquitto-python,AI领域的新宠
  • ARM Process state -- SPSR
  • 滚雪球学MySQL[5.3讲]:数据库隔离级别与一致性详解:从幻读到MVCC
  • 数据结构(二叉树)
  • 基于SpringBoot+Vue的汽车保险理赔系统
  • WDG看门狗在stm32中的应用
  • 在 VSCode IDE 中,使用 ESP32-S3 的 USB 接口进行调试
  • ElasticSearch备考 -- 异步检索
  • Node.js env 环境变量多种配置方式
  • 软件测试学习笔记丨Pytest 学习指南
  • unity 默认渲染管线材质球的材质通道,材质球的材质通道
  • 学习docker第二弹------基本命令[帮助启动类命令、镜像命令、容器命令]
  • [深度学习][python]yolov11+deepsort+pyqt5实现目标追踪
  • 28 Vue3之搭建公司级项目规范
  • Nginx编译所需基本库pcre、zlib、openssl
  • [uni-app]小兔鲜-06地址+sku+购物车