数据结构与算法:快速选择算法

Ⅰ.快速选择算法介绍:

快速选择算法思路几乎与快速排序算法相同。快速选择算法可以快速求出序列中第k小的元素。

 

Ⅱ.快速选择算法的思路:

快速选择算法可以看作是快速排序算法的“一半”。快速排序算法可以得出整个序列的大小顺序,但是,现在我只想知道第k小的元素是什么,其余的不关心。求第k小的元素而把整个序列排序又太过小题大作。

那么,现在进行的是快速排序算法,假设我选取的枢纽元是p。

在双指针交换元素之后,[ l, j ]区间是全部小于p的元素, [ j + 1, r ]区间是全部大于p的元素。

若此时 k 小于等于 j指针 ,说明答案只会在 [ l, j ] 之间。若此时k 大于 j指针,说明答案只会在[ j + 1, r]之间。则另外的区间就不必进行递归处理了,因为答案肯定不在里面,处理了也是做的无意义的花费。

 

Ⅲ.代码实现:

#include<iostream>
#include<algorithm>

using namespace std;
const int N = 100010;
int q[N];
int n, k;

void quickselect( int a[], int k, int l, int r )
{
    if( l >= r ) return;
    int pivot = a[(l+r>>1)];
    int i = l - 1, j = r + 1;
    while ( i < j ){
        while( a[++i] < pivot );
        while( a[--j] > pivot );
        if( i > j ) break;
        else swap( a[i], a[j] );
    }
    if( k <= j ) quickselect( a, k, l, j );
    else quickselect( a, k, j + 1, r );
}

int main()
{
    cin >> n >> k;
    for( int i = 0; i < n; i++ )
        cin >> q[i];
    
    quickselect( q, k - 1, 0, n - 1 );//第k个数在序列中的下标是 k-1
    cout << q[k-1] << endl;
    
    return  0;
}

 

Ⅳ.注意:

快速选择会破坏原序列元素的顺序,如果只想找出最小的第k个数而不想破坏顺序,则应该对序列的拷贝进行操作。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值