社区讨论
样例过全WA求调
P1168中位数参与者 3已保存回复 2
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 2 条
- 当前快照
- 1 份
- 快照标识符
- @lo7vw2nu
- 此快照首次捕获于
- 2023/10/27 08:37 2 年前
- 此快照最后确认于
- 2023/10/27 08:37 2 年前
写了一个自觉没问题的维护 有点类似对顶堆但又不太一样 过样例但是全WA了 -> 记录
代码如下:
CPP#include<bits/stdc++.h>
using namespace std;
const int N = 1e5+5;
int a[N];
multiset<int> l, r;
multiset<int>::iterator it;
int main()
{
int n, x;
scanf("%d", &n);
for(int i=1; i<=n; i++)
{
scanf("%d", &a[i]);
if(i & 1)
{
if(i == 1)
printf("%d\n", a[1]), x = a[1];
else
{
if(a[i] <= x && a[i-1] <= x)
{
l.insert(a[i-1]), l.insert(a[i]), r.insert(x);
it = l.end(), it --;
x = *it, l.erase(it);
}
else if(a[i] >= x && a[i-1] >= x)
{
r.insert(a[i-1]), r.insert(a[i]), l.insert(x);
it = r.begin();
x = *it, r.erase(it);
}
else
l.insert(min(a[i], a[i-1])), r.insert(min(a[i], a[i-1]));
printf("%d\n", x);
}
}
}
return 0;
}
回复
共 2 条回复,欢迎继续交流。
正在加载回复...