C语言之选择排序

简介:

选择法排序是相对好理解的排序算法。假设要对含有n个数的序列进行升序排列,算法步骤是:

1、从数组存放的n个数中找出最小数的下标(算法见下面的“求最值”),然后将最小数与第1个数交换位置;

2、除第1个数以外,再从其余n-1个数中找出最小数(即n个数中的次小数)的下标,将此数与第2个数交换位置;

3、重复步骤1  n-1趟,即可完成所求。


好了,接下来看代码:

#include <stdio.h>
#include <stdlib.h>
#define n 10 
int main()
{ 
  	 int a[n],i,j,k,t;
  	 printf("随机产生10个100以内的数:\n");
	 for(i=0;i<n;i++)
	 {
	 	a[i] = rand()%100;
	 	printf("%d\n",a[i]);
	 }
	 printf("输出:\n");
	 for(i=0;i<n-1;i++)         /*处理n-1趟*/
	 {
	 	 k = i;      /*总是假设此趟处理的第一个(即全部数的第i个)数最小,k记录其下标*/
	     for(j=i+1;j<n;j++)
		 {
	         if(a[j] < a[k])
			 	k = j; 
		 }
	     if (k != i)
		 { 
			 t = a[i]; 
			 a[i] = a[k]; 
			 a[k] = t; 
		 }
	 } 
	 for(i=0;i<n;i++)
	    printf("%d\n",a[i]); 
	    return 0 ;
}
运行结果:

随机产生10个100以内的数字,排序后输出




目录
相关文章
|
搜索推荐 算法 C语言
C语言选择排序算法,从入门到精通只需1秒!
C语言选择排序算法,从入门到精通只需1秒!
|
算法 搜索推荐 C语言
C语言进行学生成绩排序(选择排序)
用C语言进行学生成绩排序,主要包括简单选择排序和堆排序,含源代码。
479 1
C语言进行学生成绩排序(选择排序)
|
存储 搜索推荐 C语言
C语言探索:选择排序的实现与解读
C语言探索:选择排序的实现与解读
120 1
|
搜索推荐 算法 C语言
C语言:选择排序法
C语言:选择排序法
|
C语言
【C语言/数据结构】排序(选择排序,推排序,冒泡排序)
【C语言/数据结构】排序(选择排序,推排序,冒泡排序)
148 0
|
C语言
C语言的简单选择排序
C语言的简单选择排序
62 0
|
搜索推荐 算法 C语言
【排序算法】C语言实现选择排序与冒泡排序
【排序算法】C语言实现选择排序与冒泡排序
226 0
|
搜索推荐 算法 C语言
C语言实现选择排序
C语言实现选择排序
142 0
|
搜索推荐 C语言
数据结构排序——选择排序与堆排序(c语言实现)
数据结构排序——选择排序与堆排序(c语言实现)
99 0
|
搜索推荐 C语言
选择排序 - C语言实现
选择排序 - C语言实现
148 0