样例过全WA求调

P1168 中位数

fallust_papillony @ 2022-10-05 20:36:15

写了一个自觉没问题的维护 有点类似对顶堆但又不太一样 过样例但是全WA了 -> 记录

代码如下:

#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;
}

by ElmPoplar @ 2022-10-05 21:51:33

好高级的算法QwQ


by xuekaiwen_emmm @ 2023-01-02 21:18:06

看起来好厉害

话说回来,测过自测数据吗

要不先测一下看一看是哪里出问题先进行判断

作为蒟蒻的我只能给这些建议了QAQ


|