选择排序(selection sort)算法实现

从字面上理解,就是通过不断地选择数组元素,从而达到排序的目的。我插入排序类似,假设第i(i<n)个数组元素data[0]是最大的(从大到小排序),然后依次扫描i + 1 到 n - 1的元素,找到比第i个元素大的元素。最后将它们交换。
算法的时间复杂度为 O(n^2)

算法的实现如下
<!--<br /> <br /> Code highlighting produced by Actipro CodeHighlighter (freeware)<br /> http://www.CodeHighlighter.com/<br /> <br /> --> #include < stdio.h >

void output_array( int data[], int n)
{
int i;
for (i = 0 ;i < n;i ++ )
printf(
" %d " ,data[i]);
printf(
" \n " );
}
void swap( int * a, int * b)
{
int x;
x
= * a;
* a = * b;
* b = x;
}
// 算法实现
void selection( int data[], int b, int e)
{
int i,j,high_index;
for (i = b;i < e;i ++ )
{
high_index
= i;
for (j = e;j > i;j -- )
if (data[j] > data[high_index])
high_index
= j;
swap(
& data[i], & data[high_index]);
}
}
int main()
{
int data[] = { 5 , 3 , 1 , 665 , 77 , 66 , 44 , 11 , 10 , 9 , 8 , 6 };
output_array(data,
12 );
selection(data,
0 , 11 );
output_array(data,
12 );
return 0 ;
}


国内最棒的Google Android技术社区(eoeandroid),欢迎访问!

《银河系列原创教程》发布

《Java Web开发速学宝典》出版,欢迎定购

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值