算法:快速排序以及第k小元素的线性选择算法

本文介绍了快速排序算法,并详细阐述了如何使用线性选择算法在已排序的数组中找到第k小的元素。通过《data structure and algorithm analysis in c》中的实现,对算法进行了测试和验证。此外,提供了动态图示链接以帮助理解算法过程。
摘要由CSDN通过智能技术生成
简要介绍下快速排序的思想:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。时间复杂度为O(nlogn)


一.《data structure and algorithm analysis in c》中的实现,测试过,觉得该说明的已经注释

 C++ Code 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#include<stdio.h>
#define LEN  15
#define CUTOFF  3
//用c++则可以写成引用
void swap( int * const p1,  int * const p2)
{
     int tmp = *p1;
    *p1 = *p2;
    *p2 = tmp;
}
//插入排序
void insertion_sort( int a[],  int n)
{
     int i, j;
     int tmp;
     for (i =  1; i < n; i++)
    {
        tmp = a[i];
         for (j = i; j >  0 && a[j -  1] > tmp; j--)
            a[j] = a[j -  1];
        a[j] = tmp;
    }
}

// return median of left, center, and right
// order these and hide the pivot
int median3(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值