IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> LeetCode力扣Golang:十大排序算法 -> 正文阅读

[数据结构与算法]LeetCode力扣Golang:十大排序算法

按照从小到大排序

一、冒泡排序

两两相邻交换,直到相邻两个元素不再需要交换,

两层循环,第一层循环数组长度,第二层比较相邻进行交换(每一层循环总会有一个元素到达理想位置)

func BubbleSort(nums []int)[]int{
   for i:=0;i<len(nums)-1;i++{
       for j:=0;j<len(nums)-1-i;j++{
          if nums[j]>nums[j+1]{
               nums[j],nums[j+1]=nums[j+1],nums[j]
            }  
    }  
    return nums    
}

二、选择排序

冒泡的优化,在剩余的整体中交换,找到最大或最小的和自己交换可以减少减缓次数


func selectionSort(nums []int){
    
    for i := 0; i < len(nums) ; i++ {    
        minIndex := i
        for j := i + 1; j < len(nums); j++ {
            if nums[minIndex] > nums[j] {
                minIndex = j
            }
        }
    nums[i],nums[minIndex] = nums [minIndex],nums[i]

    }
}

三、插入排序

不是通过比较,而是扫描到合适的位置插入,所有插入位置后的元素向后移

适用于部分有序数组或小规模数组

自己写了下感觉没有这个哥的清晰,但是好像不导入地址导入数组数据也可以

go语言插入排序 - Go语言中文网 - Golang中文社区 (studygolang.com)

func insertSort(a []int)[]int{
   for i:=1;i<len(a);i++{
      temp := a[i]
      j := i-1
      for j >= 0 && a[j] > temp {
         a[j+1] = a[j]
         j--
      }
      if j != i-1 {
         a[j+1] = temp
      }
   }
   return a
}

四、快速排序

对冒泡的改进,分治的应用,借用分区指示器,并不需要额外数组

准备:选择基准数,和尾元素进行位置交换,设置分区指示器(默认-1)和遍历指示器

当若当前元素小于基准数:{? ? 则分区指示器向右移动一位

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 若当前元素下标大于分区指示器,则和分区指示器所指元素交换? }

关于基准数的选取:

?

实现方法:这个哥的还挺全

go_排序算法_快速排序(三种方法) - 天下医者不自医 - 博客园 (cnblogs.com)zhttps://www.cnblogs.com/ydg-941020/p/14484631.html

可不可以不开辟新的内存空间,试了下

package main

import "fmt"

func QuickSort(nums []int){
	l:= len(nums)-1
	Index:= -1
	target := nums[0]
	nums[0] , nums[l] = nums[l],nums[0]

	for i := 0 ;i<len(nums);i++{
		if nums[i] < target{
			Index = Index+ 1
			if i >Index{
				nums[Index],nums[i] = nums[i],nums[Index]
            }
        }
    }
	//m,n := nums[:Index+1],nums[Index+1:l+1]
	var m =  make([]int,Index+1)
	var n = make([]int,l-Index+1)
	m,n = nums[:Index+1],nums[Index+1:l+1]
QuickSort(m)
QuickSort(n)
}

func main()  {
	nums := []int{88,44,66,75,95,13,4,6}
	QuickSort(nums)
	fmt.Println(nums)
}

出错了:panic: runtime error: index out of range [0] with length 0

下标越界,两个参考:

(4条消息) go 切片报错 panic:runtime error:index out of range [0] with length 0_雅晴一点不笨的博客-CSDN博客https://blog.csdn.net/m0_49049914/article/details/119793788(4条消息) panic: runtime error: index out of range [0] with length 0 goroutine 1 [running]: 数组越界的常犯错误统计_海鸟鱼与海的博客-CSDN博客https://blog.csdn.net/ccsnail00/article/details/107441078

改了一个好像不是这个,等我明天再研究下

?五、希尔排序/缩小增量排序

基于插入排序的快速排序,

设置增量,每次依照增量进行分组,然后插入排序让组内有序,再不断缩小增量

增量序列递减最后为1即可,目前还没有最好序列,目前常用:?

六、归并排序

递归和分治将序列划分为越来越小的半子表,对半子表排序后再用递归将排好的半子表合并为越来越大的有序序列

?

(4条消息) 用 Go 学算法--归并排序_煎鱼(EDDYCJY)的博客-CSDN博客

大哥写的挺清楚的,最后result那里竟然还有个解压切片,之前没见过

详细看这里:【转】golang 三个点省略号的作用总结 - 简书 (jianshu.com)


 
import "fmt"
 
// 自顶向下归并排序,排序范围在 [begin,end) 的数组
func MergeSort(array []int, begin int, end int) {
    // 元素数量大于1时才进入递归
    if end - begin > 1 {
 
        // 将数组一分为二,分为 array[begin,mid) 和 array[mid,high)
        mid := begin + (end-begin+1)/2
 
        // 先将左边排序好
        MergeSort(array, begin, mid)
 
        // 再将右边排序好
        MergeSort(array, mid, end)
 
        // 两个有序数组进行合并
        merge(array, begin, mid, end)
    }
}
 
// 归并操作
func merge(array []int, begin int, mid int, end int) {
    // 申请额外的空间来合并两个有序数组,这两个数组是 array[begin,mid),array[mid,end)
    newSize := end-begin+1 // 辅助数组的长度
    result := make([]int, 0, newSize)
 
    l, r := 0, 0
    for l < leftSize && r < rightSize {
        lValue := array[begin+l] // 左边数组的元素
        rValue := array[mid+r]   // 右边数组的元素
        // 小的元素先放进辅助数组里
        if lValue < rValue {
            result = append(result, lValue)
            l++
        } else {
            result = append(result, rValue)
            r++
        }
    }
 
    // 将剩下的元素追加到辅助数组后面
    result = append(result, array[begin+l:mid]...)
    result = append(result, array[mid+r:end]...)
 
    // 将辅助数组的元素复制回原数组,这样该辅助空间就可以被释放掉
    for i := 0; i < newSize; i++ {
        array[begin+i] = result[i]
    }
    return
}

?七、堆排序

采用二叉堆:完全二叉树

?

最后一个非叶子结点的数组位置:len/2-10

先构成当前的最大堆,然后与最后一个结点比较并交换位置,循环往复

?

(4条消息) 堆排序-golang语言实现_触不可及<>的博客-CSDN博客_golang 堆排序

八、计数排序、基数排序、桶排序

:都利用了桶的概念,但适用法有差异

计数排序:需要额外空间

新建一个计数数组,原数组的值出现几次,将计数数组的对应下标位置计几,然后把原数组按照对应下标的个数存入

??

实际为了节省空间,会找出数组的max和min,注意适用范围

基数排序:从右向左依次入桶,根据键值的每位数字来分配桶

依次实现个位、十位桶……最大位数,决定几轮排序,然后依次输入

?

?桶排序:每个桶存储一定范围内的值

重点是确定桶的容量

总结:

?稳定性:相等元素排序前后顺序不变

快速排序与归并排序时间复杂度一样,但快速的常数因子小得多,空间复杂度低

快排的最坏情况体现在基准数的选择

有的时候会频繁出栈入栈,可能反而会增大时间复杂度,可以综合使用插入和快排

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-09-21 00:52:38  更:2022-09-21 00:54:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 21:20:16-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码