| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> Java选择排序算法(select sorting) -> 正文阅读 |
|
[数据结构与算法]Java选择排序算法(select sorting) |
选择排序思想选择排序(select sorting)也是一种简单的排序方法。他的基本思想是:第一次从arr[0]~arr[n-1]中选取最小值,与arr[0]交换,第二次从arr[1] arr[n-1]中选取最小值,与arr[1]交换,第三次从arr[2] ~ arr[n-1]中选取最小值,与arr[2]交换,…,第n-1次从arr[n-2] ~ arr[n-1]中选取最小值,与arr[n-2]交换,总共通过n-1次,得到一个按排序码从小到大排列的有序序列。 思路分析 数组初始数据为 9,16,21,23,30,49,20,27 第一趟排序从该数组中找到一个最小值放到第一位,因为9就是该数组中最小值,所以不进行位置交换。得到 9,16,21,23,30,49,20,27 第二趟排序从该数组的第二个数开始寻找该数组中最小的一位,放在第二个位置,16为该数组第二小的数据所以也不进行交换。得到 9,16,21,23,30,49,20,27 第三趟排序从该数组第三个数开始寻找,放在第三个位置。20比21小所以进行交换。得到 9,16,20,23,30,49,21,27 以此类推最终得到 9,16,20,21,23,27,30,49 说明 选择排序一个有数组大小 -1 轮排序 每一轮排序,又是一个循环,循环的规则(代码)。先假定当前这个数是最小数。然后和后面的每个数进行比较,如果发现有比当前数更小的数,就重新确定最小数,并得到下标。当遍历到数组的最后时,就得到本轮最小数和下标。进行互相交换。 代码实现使用逐步推导的方式来,讲解选择排序,假定min为最小值,minInde为最小值的索引,进入循环后如果min>arr[j]就进行位置交换,并把索引位置给到minIndex
如果想进行从大到小排序呢? 我们只需要对判断进行稍微改变即可
性能测试
经多次测试我们选择排序的平均速度为两秒比冒泡排序速度还是快了很多 (冒泡排序文章导航:https://blog.csdn.net/weixin_45692705/article/details/124894717?spm=1001.2014.3001.5501) |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
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/26 1:57:25- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |