社区讨论

大佬们为啥我用了快排还是不行啊

P1923【深基9.例4】求第 k 小的数参与者 4已保存回复 5

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
5 条
当前快照
1 份
快照标识符
@m2g6e1nz
此快照首次捕获于
2024/10/19 21:09
去年
此快照最后确认于
2025/11/04 16:47
4 个月前
查看原帖
C
#include<bits/stdc++.h>
using namespace std;

int a[1000000];
int n,k;
//
void wwqsort(int arr[],int l,int r)
{
	if (l >= r) return;
	int mid = (l + r) / 2;
	swap(arr[l],arr[mid]);
	
	int i = l + 1,j = r;
	
	while (i <= j)
	{
		while (i <= j && arr[i] < arr[l]) i++;
		while (i <= j && arr[j] > arr[l]) j--;
		if (i <= j)
		{
			swap (arr[i],arr[j]);
			i++,j--;
		}
	}
	swap(arr[l],arr[j]);
	wwqsort(arr,l,j - 1);
	wwqsort(arr,j + 1,r);
}
int main()
{
	cin >> n >> k;
	for (int i = 1;i <= n;i++)
	{
		cin >> a[i];
	}
	wwqsort(a,1,n);
	cout << a[k];
	return 0;
}

回复

5 条回复,欢迎继续交流。

正在加载回复...