求一个好的排序算法
有知道更好的排序方法的吗,我这个代码后面超时了
万分感谢!
看着题目晕乎,每行两个数是pi,qi,那ai从哪来的呢?
首先读入两个数n和m,然后开始执行m次操作,每次操作会读入两个数p和q。当p=0时,算法会将q作为一个分界线,将当前栈顶元素中x为0且y大于等于q的所有元素弹出,并将栈顶元素的y与q取max作为新的q,然后将当前栈顶元素中y小于等于q的所有元素弹出,最后将一个新的元素{0,q}入栈。当p=1时,算法会将q作为一个分界线,将当前栈顶元素中x为1且y小于等于q的所有元素弹出,并将栈顶元素的y与q取min作为新的q,然后将当前栈顶元素中y大于等于q的所有元素弹出,最后将一个新的元素{1,q}入栈。
#include <iostream>
#include <cstring>
#include <algorithm>
#define x first
#define y second
using namespace std;
typedef pair<int, int> PII;
const int N = 100010;
int n, m;
PII stk[N];
int ans[N];
int main()
{
cin>>n>>m;
int top = 0;
while (m -- )
{
int p, q;
cin>>p>>q;
if (!p)
{
while (top && stk[top].x == 0) q = max(q, stk[top -- ].y);
while (top >= 2 && stk[top - 1].y <= q) top -= 2;
stk[ ++ top] = {0, q};
}
else if (top)
{
while (top && stk[top].x == 1) q = min(q, stk[top -- ].y);
while (top >= 2 && stk[top - 1].y >= q) top -= 2;
stk[ ++ top] = {1, q};
}
}
int k = n, l = 1, r = n;
for (int i = 1; i <= top; i ++ )
{
if (stk[i].x == 0)
while (r > stk[i].y && l <= r) ans[r -- ] = k -- ;
else
while (l < stk[i].y && l <= r) ans[l ++ ] = k -- ;
if (l > r) break;
}
if (top % 2)
while (l <= r) ans[l ++ ] = k -- ;
else
while (l <= r) ans[r -- ] = k -- ;
for (int i = 1; i <= n; i ++ )
cout<<ans[i]<<" ";
return 0;
}
最快的排序,当然是快速排序了,而且没必要自己写,直接调用 qsort