社区讨论
我这是慢排QAQ,3.2s,求怎么改
P1177【模板】排序参与者 3已保存回复 2
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 2 条
- 当前快照
- 1 份
- 快照标识符
- @lo7p8j7e
- 此快照首次捕获于
- 2023/10/27 05:31 2 年前
- 此快照最后确认于
- 2023/10/27 05:31 2 年前
CPP
#include <iostream>
#include <algorithm>
using namespace std;
int arr[100001];
void quicksort(int a, int b)
{
if (a >= b) return;
int i, j, temp;
temp = arr[a];
i = a; j = b;
while (i != j)
{
while (arr[j] >= temp && j > i)
{
j--;
}
while (arr[i] <= temp && i < j) {
i++;
}
if (i < j)
{
swap(arr[i], arr[j]);
}
}
arr[a] = arr[i];
arr[i] = temp;
quicksort(a, i - 1);
quicksort(i + 1, b);
}
int main()
{
int n;
cin >> n;
for (int i = 1; i <= n; i++)
{
cin >> arr[i];
}
quicksort(1, n);
for (int i = 1; i <= n; i++)
{
cout << arr[i]<<" ";
}
return 0;
}
回复
共 2 条回复,欢迎继续交流。
正在加载回复...