【算法】快速排序2

题目

给定一个长度为 n 的整数数列,以及一个整数 k,请用快速选择算法求出数列从小到大排序后的第 k个数。
输入格式

第一行包含两个整数 n和 k。

第二行包含 n个整数(所有整数均在 1∼10^9范围内),表示整数数列。
输出格式

输出一个整数,表示数列的第 k 小数。
数据范围

1≤n≤100000, 1≤k≤n
输入样例:

5 3 2 4 1 5 3
输出样例:

3

来源:acwing算法基础 786. 第k个数


思路(注意事项)

while给漏了:一次递归要循环到 i 与 j 相遇为止。


题解

c 复制代码
#include<bits/stdc++.h>

using namespace std;

const int N = 100000;
int n;
int a[N];

void qsort (int a[], int l,int r)
{
	if (l >= r) return;
	
	int x = a[(l + r) / 2 ];
	int i = l - 1, j = r + 1;
	
	while (i < j)
	{
	do i ++; while(a[i] < x);
	do j --; while(a[j] > x);
	if (i < j) swap (a[i], a[j]);
	}
	
	qsort (a, l, j);
	qsort (a, j + 1, r);
}

int main()
{
	int n, k;
	cin >> n >> k;
	
	for (int i = 0; i < n; i ++)
		cin >> a[i];
	
	qsort(a, 0, n - 1);
	cout << a[k - 1];
}
相关推荐
wow_DG22 分钟前
【C++✨】多种 C++ 解法固定宽度右对齐输出(每个数占 8 列)
开发语言·c++·算法
Epiphany.55631 分钟前
c++最长上升子序列长度
c++·算法·图论
Cx330❀1 小时前
【数据结构初阶】--排序(四):归并排序
c语言·开发语言·数据结构·算法·排序算法
余_弦1 小时前
区块链中的密码学 —— 密钥派生算法
算法·区块链
亲爱的非洲野猪2 小时前
令牌桶(Token Bucket)和漏桶(Leaky Bucket)细节对比
网络·算法·限流·服务
颖川守一2 小时前
C++c6-类和对象-封装-设计案例2-点和圆的关系
开发语言·c++
NAGNIP2 小时前
一文读懂LLAMA
算法
烧冻鸡翅QAQ2 小时前
62.不同路径
算法·动态规划
番薯大佬2 小时前
编程算法实例-冒泡排序
数据结构·算法·排序算法
queenlll2 小时前
P2404 自然数的拆分问题(典型的dfs)
算法·深度优先