加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 服务器 > 安全 > 正文

算法—选择排序

发布时间:2021-03-18 19:06:22 所属栏目:安全 来源:网络整理
导读:选择排序 选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有

选择排序

选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。换个说法就是,选定一个位置,然后和后面的每一个位置比较。

如arr[10] = {8,5,2,6,9,3,1,4,7}

首先arr[0]和arr[1]比较,因为arr[1]>arr[0]故,arr[0] = 5,arr[1] = 8;

然后再拿arr[0]和arr[2]比较,因为arr[0]>arr[2]故,arr[0] = 2,arr[2] = 5;

继续再拿arr[0]和arr[3]比较......

直至到arr[0]和arr[9]比较,然后可以得出第一个arr[0]为该数组的最小值;

第一轮排序后的顺序为arr[10] = {0,8,7}。

然后从arr[1]和arr[2]比较,因为arr[1]>arr[2]故,arr[1] = 5,arr[2] = 8;

然后再拿arr[1]和arr[3]比较......

直至到arr[1]和arr[9]比较,然后可以得出第二个arr[1]为该数组的第二小值;

第二轮排序后的顺序为arr[10] = {0,7}。

....直至一直到最后一轮,排序即可完成.

arr[10] = {0,7,9}.

过程演示:

算法—选择排序

算法—选择排序

?

算法—选择排序

算法—选择排序

 1 #include <stdio.h>
 2 void swap(int *a,int *b) //交換兩個變數
 3 {
 4     int temp = *a;
 5     *a = *b;
 6     *b = temp;
 7 }
 8 void selection_sort(int arr[],1)">int len) 
 9 10      i,j;
11  
12     for (i = 0 ; i < len - 1 ; i++) 
13     {
14         int min = i;
15         for (j = i + 1; j < len; j++)     走訪未排序的元素
16             if (arr[j] < arr[min])    找到目前最小值
17                 min = j;    紀錄最小值
18            swap(&arr[min],&arr[i]);    做交換
19     }
20 21 
22  main() {
23     int arr[] = { 22,34,1)">3,1)">32,1)">82,1)">55,1)">89,1)">50,1)">37,1)">5,1)">64,1)">35,1)">9,1)">70 };
24     int len = (int) sizeof(arr) / sizeof(*arr);
25     26     selection_sort(arr,len);
27   
28     0; i < len; i++)
29         printf("%d ",arr[i]);
30     return 0;
31 }
selection_sort 如果实在是不理解,那么观看下面这个视频应该会有所理解了。这个视频还是挺有意思的,请认真看完,如果不行就加速看也行。第一次看不懂就多看几遍然后和代码联系上。 跳转视频 ?

若有视频侵权,请联系本人。本人删除

? ? ? ? ? ?

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读