第 22 题:如何理解选择排序?
2021/8/17 13:06:06
本文主要是介绍第 22 题:如何理解选择排序?,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
什么是选择排序?
基本思想:在一个排列中划分为有序区和无序区,有序区在左边,无序区在右边。首先在无序区中找到最小(大)元素,存放到有序区的起始位置,然后,再从剩余的无序区中继续寻找最小(大)元素,然后放到有序区的末尾。以此类推,直到无序区没有元素可排列
直观表达:就是在一个数组中遍历查找,找到小的放在数组的左侧,然后在剩余的元素中继续查找,直到排序完成
算法描述
假设一个数组中有 2 个区域
5, 8, 2, 3, 1
有序区为空,无序区为 5, 8, 2, 3, 1
-----------------------------------
首先:记录数组的第一个值(5),看看还有没有比它更小的,如果有则记录下来(1)。直到数组第一遍遍历完成。然后把最小的值(1)和无序区的第一个值(5)交换位置
结果:1, 8, 2, 3, 5
有序区为 1,无序区为 8, 2, 3, 5
-----------------------------------
然后进行第二遍遍历,在无序区中继续查找最小值(2),遍历完毕后将最小值(2)与无序区第一值(8)交换位置
结果:1, 2, 8, 3, 5
有序区为 1, 2,无序区为 8, 3, 5
-----------------------------------
… 以此类推,直到无序区为空
这篇关于第 22 题:如何理解选择排序?的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-05小米13T Pro系统合集:性能与摄影的极致融合,值得你升级的系统ROM
- 2024-10-01基于Python+Vue开发的医院门诊预约挂号系统
- 2024-10-01基于Python+Vue开发的旅游景区管理系统
- 2024-10-01RestfulAPI入门指南:打造简单易懂的API接口
- 2024-10-01初学者指南:了解和使用Server Action
- 2024-10-01Server Component入门指南:搭建与配置详解
- 2024-10-01React 中使用 useRequest 实现数据请求
- 2024-10-01使用 golang 将ETH账户的资产平均分散到其他账户
- 2024-10-01JWT用户校验课程:从入门到实践
- 2024-10-01Server Component课程入门指南