【算法】快速排序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];
}
相关推荐
AlgoNewbie几秒前
牛客周赛 Round 88【题解完成】
算法
whoarethenext22 分钟前
基于libevent写一个服务器(附带源码)
linux·运维·服务器·c++·后端
luckycoding38 分钟前
2747. 统计没有收到请求的服务器数目
算法
zyx没烦恼1 小时前
Linux 多线程
linux·运维·服务器·开发语言·c++
愚润求学1 小时前
【C++】模板进阶
c语言·开发语言·c++·笔记·模板
seaeress1 小时前
opencv(C++)处理图像颜色
c++·人工智能·opencv
xyd陈宇阳1 小时前
C++ 入门三:函数与模板
开发语言·c++
oioihoii2 小时前
C++23新特性详解:迈向更现代化的C++
开发语言·c++·c++23
TT哇2 小时前
【前缀和】矩阵区域和(medium)
java·线性代数·算法·矩阵
darkchink2 小时前
[LevelDB]Block系统内幕解析-元数据块(Meta Block)&元数据索引块(MetaIndex Block)&索引块(Index Block)
android·java·服务器·c语言·数据库·c++·分布式