【算法】快速排序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];
}
相关推荐
梦星辰.2 分钟前
VSCode CUDA C++进行Linux远程开发
linux·c++·vscode
whoarethenext1 小时前
C++ OpenCV 学习路线图
c++·opencv·学习
eachin_z1 小时前
力扣刷题(第四十九天)
算法·leetcode·职场和发展
闻缺陷则喜何志丹1 小时前
【强连通分量 缩点 拓扑排序】P3387 【模板】缩点|普及+
c++·算法·拓扑排序·洛谷·强连通分量·缩点
hutaotaotao1 小时前
c++中的输入输出流(标准IO,文件IO,字符串IO)
c++·io·fstream·sstream·iostream
机器学习之心1 小时前
机器学习用于算法交易(Matlab实现)
算法·机器学习·matlab
AL流云。1 小时前
【优选算法】C++滑动窗口
数据结构·c++·算法
qq_429879673 小时前
省略号和可变参数模板
开发语言·c++·算法
CodeWithMe4 小时前
【C/C++】std::vector成员函数清单
开发语言·c++
uyeonashi4 小时前
【QT控件】输入类控件详解
开发语言·c++·qt