选择排序是一种攻击性算法,它的工作原理是从数组中找到最小的数字,然后将其放在第一个位置。下一个要遍历的数组将从最小数字所在位置的下一个索引开始。
让我们举个例子来更清楚地说明这个概念。
我们有一个数组 {6, 3, 8, 12, 9} 在这个数组中最小的元素是 3。所以我们将 3 放在第一个位置,之后数组将看起来像 {3, 6, 8, 12, 9} 。现在我们将再次找到最小的数字,但这次我们不会在搜索中考虑 3,因为它在它的位置。找到下一个最小元素 6,在第二个位置创建一个包含 6 的数组,然后再次在数组中搜索,直到数组排序完毕。
选择排序算法的工作原理 –
选择排序算法遵循以下步骤
让我们采用一个数组 {20, 12 , 23, 55 ,21}
将数组的第一个元素设置为最小值。
最小值= 20
将最小值与下一个元素进行比较,如果它小于最小值分配该元素为最小值。这样做直到数组末尾。
与 12 : 20 > 12 比较,最小值 = 12
与 23 : 12 与 55 比较:12
与 21 比较:12
将最小值放在数组的第一个位置(索引 0)。
Array = {12, 20 ,23, 55, 21}
对于下一次迭代,开始从第一个未排序元素开始排序。
Array = {12, 20 ,23, 55, 21}
从 20 开始搜索,下一个放置最小值的元素。
迭代 2:
最小值 = 20
与 23 相比:20
与 55 相比:20
与 21 相比:20
最小值不变,
数组 = {12, 20 ,23, 55, 21}
迭代 3:
最小值 = 23。
与 55 相比:23
与 21 相比: 23 > 21 ,最小值 = 21
最小值移至索引 = 2
Array = {12, 20, 21, 55, 23}
迭代 4:
最小值 = 55
与 23 相比:23
最小值移至索引 3数组 = { 12 , 20 , 21 , 23 , 55 }
示例
#include int main() { int arr[10]={6,12,0,18,11,99,55,45,34,2}; int n=10; int i, j, position, swap; for (i = 0; i arr[j]) position = j; } if (position != i) { swap = arr[i]; arr[i] = arr[position]; arr[position] = swap; } } for (i = 0; i输出
0 2 6 11 12 18 34 45 55 99登录后复制
以上就是选择排序的C程序的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2585645.html