排序算法之简单选择排序

Posted 数据结构C语言版

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了排序算法之简单选择排序相关的知识,希望对你有一定的参考价值。

八大排序算法之简单选择排序

No.1  基本思想

在要排序的一组数中,选出最小的一个数与第一个位置的数交换;然后在剩下的数当中再找最小的与第二个位置的数交换,如此循环到倒数第二个数和最后一个数比较为止。

No.2 实例


No.3  C语言程序实现

程序框可以左右滑动哦~
#include<stdio.h>
#include<windows.h>
int main()
{
   int a[] = {1,54,6,3,78,34,12,45};
   int n= 8;
   int i,j;
   for(i=0;i<n;i++)
   {
       printf("%d\t",a[i]);
   }
   printf("\n");
   int position,temp;
   for(i=0;i<n;i++)
   {
       position = i;
       temp = a[i];
       for(j=i+1;j<n;j++)
       {
           if(a[j]<temp)
           {
               temp = a[j];
               position = j;
           }
       }
       a[position] = a[i];
       a[i] = temp;
   }
   for(i=0;i<n;i++)
   {
       printf("%d\t",a[i]);
   }
   printf("\n");
   system("pause");
   return 0;
}


动画展示:



以上是关于排序算法之简单选择排序的主要内容,如果未能解决你的问题,请参考以下文章

数据结构与算法之排序算法:选择排序

排序算法之选择排序(简单选择排序堆排序)

经典算法之选择排序

排序算法系列之选择排序

[Java数据结构与算法]简单排序之插入排序

8大常见排序算法之选择排序!