| |
|
开发:
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:十大排序算法 |
按照从小到大排序一、冒泡排序两两相邻交换,直到相邻两个元素不再需要交换, 两层循环,第一层循环数组长度,第二层比较相邻进行交换(每一层循环总会有一个元素到达理想位置)
二、选择排序冒泡的优化,在剩余的整体中交换,找到最大或最小的和自己交换可以减少减缓次数
三、插入排序不是通过比较,而是扫描到合适的位置插入,所有插入位置后的元素向后移 适用于部分有序数组或小规模数组 自己写了下感觉没有这个哥的清晰,但是好像不导入地址导入数组数据也可以 go语言插入排序 - Go语言中文网 - Golang中文社区 (studygolang.com)
四、快速排序对冒泡的改进,分治的应用,借用分区指示器,并不需要额外数组 准备:选择基准数,和尾元素进行位置交换,设置分区指示器(默认-1)和遍历指示器 当若当前元素小于基准数:{? ? 则分区指示器向右移动一位 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 若当前元素下标大于分区指示器,则和分区指示器所指元素交换? } 关于基准数的选取: ? 实现方法:这个哥的还挺全 go_排序算法_快速排序(三种方法) - 天下医者不自医 - 博客园 (cnblogs.com)zhttps://www.cnblogs.com/ydg-941020/p/14484631.html 可不可以不开辟新的内存空间,试了下
出错了: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)
?七、堆排序采用二叉堆:完全二叉树 ? 最后一个非叶子结点的数组位置:len/2-10 先构成当前的最大堆,然后与最后一个结点比较并交换位置,循环往复 ? (4条消息) 堆排序-golang语言实现_触不可及<>的博客-CSDN博客_golang 堆排序 八、计数排序、基数排序、桶排序:都利用了桶的概念,但适用法有差异 计数排序:需要额外空间新建一个计数数组,原数组的值出现几次,将计数数组的对应下标位置计几,然后把原数组按照对应下标的个数存入 ?? 实际为了节省空间,会找出数组的max和min,注意适用范围 基数排序:从右向左依次入桶,根据键值的每位数字来分配桶依次实现个位、十位桶……最大位数,决定几轮排序,然后依次输入 ? ?桶排序:每个桶存储一定范围内的值重点是确定桶的容量 总结:?稳定性:相等元素排序前后顺序不变 快速排序与归并排序时间复杂度一样,但快速的常数因子小得多,空间复杂度低 快排的最坏情况体现在基准数的选择 有的时候会频繁出栈入栈,可能反而会增大时间复杂度,可以综合使用插入和快排 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
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年12日历 | -2024/12/28 18:59:04- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |
数据统计 |