| |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| -> 数据结构与算法 -> 选择排序实现 -> 正文阅读 |
|
|
[数据结构与算法]选择排序实现 |
|
选择排序是排序算法中较为基础的排序算法。本人对选择排序的理解为: 存在一个数组,数组中存放着N个无序数。 实现: ??????? 在使用选择排序时,排序的每一趟最终目标是将某一个数和另外一个数进行位置交换,将其放在合适的位置,其他数的相对位置不变。(与冒泡不同在于,冒泡没有交换两个数的位置) 时间复杂度理解: ??????? 假设将数组中的每一个数对应二维表中的每一列,那么这个列表有N列,排序的每一趟当做列表中的每一行,那么这个列表有N-1行。之所以只有N-1行是当N-1个数字排序完毕,最后一个(第N个)数自然就在正确的位置。因此选择排序就够成了一张N*(N-1)的表格。由此可以看出从排序第一趟第一个数走到排序最后一趟(即N-1趟)最后一个数(第N个数),程序的时间复杂度为N^2-N.利用大O记法,可以记O(N^2),由此可知选择排序比较适用于数据量较小的双层循环。 在本人看来冒泡排序和选择排序有相同地方,当然也有一定差别。相同之处都存在元素大小比较,元素交换。不同之处在于,选择排序玩的是数组元素下标,冒泡排序玩的是数组元素。 以下是选择排序的java语言实现:
运行结果如下:
以下是C语言代码实现:
其运行结果如下:
? 相关排序: 以上是本人对选择排序算法的个人理解,不喜勿喷,感谢理解。 |
|
|
|
|
| 上一篇文章 下一篇文章 查看所有文章 |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| 360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年10日历 | -2025/10/24 7:38:16- |
|
| 网站联系: qq:121756557 email:121756557@qq.com IT数码 |