第 22 题:如何理解选择排序?

Posted Noxus丶SJ

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第 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 题:如何理解选择排序?的主要内容,如果未能解决你的问题,请参考以下文章

第 23 题:如何理解插入排序?

第 24 题:如何理解希尔排序?

第 25 题:如何理解归并排序?

第 26 题:如何理解快速排序?

第 30 题:如何理解基数排序?

第 27 题:如何理解堆排序?