首页 > 编程语言 > 详细

C语言之选择排序

时间:2016-02-09 19:59:12      阅读:229      评论:0      收藏:0      [点我收藏+]

选择法排序是相对好理解的排序算法。假设要对含有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语言之选择排序

原文:http://blog.csdn.net/morixinguan/article/details/50647037

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!