社区讨论
为什么STL的排序快一点
学术版参与者 5已保存回复 9
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 9 条
- 当前快照
- 1 份
- 快照标识符
- @lrmz5o7l
- 此快照首次捕获于
- 2024/01/21 12:04 2 年前
- 此快照最后确认于
- 2024/01/21 15:00 2 年前
rt,本人手打的快排:
CPP#include<bits/stdc++.h>
using namespace std;
const int N=1e6+5;
int n;
int a[N];
void quicksort(int left,int right)
{
if(left>right)
{
return;
}
int temp=a[left];
int i=left,j=right;
while(i!=j)
{
while(a[j]>=temp&&i<j)
{
j--;
}
while(a[i]<=temp&&i<j)
{
i++;
}
if(i<j)
{
swap(a[i],a[j]);
}
}
a[left]=a[i];
a[i]=temp;
quicksort(left,i-1);
quicksort(i+1,right);
return;
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
}
quicksort(1,n);
for(int i=1;i<=n;i++)
{
printf("%d ",a[i]);
}
return 0;
}
模板题 40pts。
回复
共 9 条回复,欢迎继续交流。
正在加载回复...