zoukankan      html  css  js  c++  java
  • 算法—选择排序

    选择排序

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

    如arr[10] = {8,5,2,6,9,3,1,4,0,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,5,6,9,3,2,4,1,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,1,8,6,9,5,3,4,2,7}。

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

    arr[10] = {0,1,2,3,4,5,6,7,8,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[], int len) 
     9 {
    10     int 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 int main() {
    23     int arr[] = { 22, 34, 3, 32, 82, 55, 89, 50, 37, 5, 64, 35, 9, 70 };
    24     int len = (int) sizeof(arr) / sizeof(*arr);
    25     int i;
    26     selection_sort(arr, len);
    27   
    28     for (i = 0; i < len; i++)
    29         printf("%d ", arr[i]);
    30     return 0;
    31 }
    selection_sort
    如果实在是不理解,那么观看下面这个视频应该会有所理解了。这个视频还是挺有意思的,请认真看完,如果不行就加速看也行。第一次看不懂就多看几遍然后和代码联系上。
    跳转视频
     

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

     
     
     
     
     
     
  • 相关阅读:
    Android学习笔记37-使用Content Providers方式共享数据
    Android学习笔记36-使用SQLite方式存储数据
    Android学习笔记35-使用Shared Preferences方式存储数据
    Android学习笔记34-使用文件存储数据
    Android学习笔记33-Intent介绍及Intent在Activity中的使用方法
    Android学习笔记32-滑屏控件ViewPager的使用
    Android学习笔记31-使用惰性控件ViewStub实现布局动态加载
    Android学习笔记30-列表ListView控件的使用
    Android学习笔记29-切换卡TabHost控件的使用
    用户代理
  • 原文地址:https://www.cnblogs.com/CSAH/p/10970888.html
Copyright © 2011-2022 走看看