QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#769161 | #7787. Maximum Rating | guodong# | WA | 0ms | 3608kb | C++17 | 2.5kb | 2024-11-21 16:23:06 | 2024-11-21 16:23:11 |
Judging History
answer
#include <bits/stdc++.h>
#define int long long
const int inf = 1e9;
using namespace std;
#define For(i,a,b) for(int i = a; i <= b; ++i)
class sgt{
public:
int n,num,root ;
vector<int> cnt,sum,ls,rs;
sgt(int _n){
n = _n;
num = 1;
root = 1;
sum.resize(n * 35);
cnt.resize(n * 35);
ls.resize(n * 35);
rs.resize(n * 35);
}
#define mid ((l + r ) >> 1ll)
void update(int &pos,int l,int r,int x,int v,int flag){
if(!pos) pos = ++num;
cnt[pos] += flag;
sum[pos] += v * flag;
if(l == r) return;
if(x <= mid)
update(ls[pos],l,mid,x,v,flag);
else
update(rs[pos],mid + 1,r,x,v,flag);
}
pair<int,int> query(int pos,int l,int r,int cur){
// if(!sum[pos])
if(!pos)
return make_pair(0,0);
if(l == r){
if(cur + sum[pos] > 0){
return make_pair(sum[pos] / l,1);
}
else
return make_pair(0,0);
}
pair<int,int> ansl, ansr ;
ansl = ansr = make_pair(0,0);
ansl = query(ls[pos],l,mid,cur);
if(ansl.second == 1){
return ansl;
}
ansr = query(rs[pos],mid + 1,r,cur + sum[ls[pos]]);
if(ansr.second == 1){
ansr.first += cnt[ls[pos]];
return ansr;
}
return make_pair(0,0);
}
void del(int v){
update(root,-inf,inf,v,v,-1);
}
void add(int v){
update(root,-inf,inf,v,v,1);
}
int Q(){
return query(root,-inf,inf,0).first;
}
};
signed main()
{
#ifdef NICEGUODONG
freopen("data.in","r",stdin);
#endif
int n,q;
cin >> n >> q;
vector<int> a(n + 1);
int maxx = 0;
For(i,1,n){
cin >> a[i];
maxx += a[i] > 0;
}
sgt t = sgt(n + q);
For(i,1,n)
t.add(a[i]);
For(i,1,q){
int x,v;
cin >> x >> v;
t.del(a[x]);
maxx -= a[x] > 0;
a[x] = v;
t.add(a[x]);
maxx += a[x] > 0;
int pref = t.Q();
if(pref == 0)
pref = 0;
else
pref = n - pref + 1;
cout << maxx - pref + 1 << '\n';
}
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 3608kb
input:
3 5 1 2 3 3 4 2 -2 1 -3 3 1 2 1
output:
1 2 2 2 3
result:
ok 5 number(s): "1 2 2 2 3"
Test #2:
score: -100
Wrong Answer
time: 0ms
memory: 3544kb
input:
3 5 1 2 3 3 4 2 -2 1 3 3 1 2 1
output:
1 2 1 2 2
result:
wrong answer 5th numbers differ - expected: '1', found: '2'