选择排序

最坏时间复杂度,最佳时间复杂度,平均时间复杂度都是O(n^2)

相比冒泡排序的优势是 每次扫描只保存索引,并不交换,节省了时间。但是冒泡排序可以设置标志位提前结束排序,较于选择排序也节省了时间。

一次性放到终态位置:是

稳定性:稳定;前提是 if ( a[ j ] >= a[ k ] )   k = j;  而不是 if ( a[ j ] >=a[ k ] )   k = j;

 1 #include"头文件.h"
 2 void SelectSort(int *a, int len) {
 3     if (a == null || len < 1)
 4         return;
 5     int k;//保存最大元素的索引
 6     int temp;//swap两个变量的临时变量
 7     for (int i = len - 1; i >= 0; --i) {
 8         k = 0;
 9         for (int j = 0; j <= i; ++j) {
10             if (a[j] > a[k])
11                 k = j;
12         }
13         temp = a[k];
14         a[k] = a[i];
15         a[i] = temp;
16     }
17 }
18 int main() {
19     int a[100];
20     for (int i = 0; i < 100; ++i) {
21         a[i] = 1 + rand() % 500;
22     }
23     printf("排序前的数组:\n");
24     for (int i = 0; i < 100; ++i) {
25         printf("%4d ", a[i]);
26         if ((i + 1) % 10 == 0)
27             printf("\n");
28     }
29     printf("\n");
30     printf("排序后的数组:\n");
31     SelectSort(a, 100);
32     for (int i = 0; i < 100; ++i) {
33         printf("%4d ", a[i]);
34         if ((i+1) % 10 == 0)
35             printf("\n");
36     }
37     printf("\n");
38     system("pause");
39     return 0;
40 }

转载于:https://www.cnblogs.com/joyeehe/p/7861554.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值