40分(4TLE)求改进

P1168 中位数

pyq123 @ 2023-08-18 15:49:51

#include<iostream>
#include <vector>
#include<algorithm>
using namespace std;
int main()
{
    int p,n,i,j;
    cin>>p;
    vector<int> a(p);
    for(i=0;i<p;i++)
        cin>>a[i];
    for(i=0;i<p;i+=2)
    {
        vector<int> b(i+1); 
        for(j=0;j<=i;j++)
            b[j]=a[j];
        sort(b.begin(),b.end());
        cout<<b[i/2]<<endl;
    }
}

by ppchnb @ 2023-09-02 16:37:38

不能用sort,n*nlogn数据抵不住

建议二分插入 应该式nlogn属于正解了


by Molie @ 2023-11-20 19:49:22

使用权值线段树...


|