QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#596190 | #7736. Red Black Tree | zhangboju | TL | 1179ms | 33040kb | C++14 | 2.0kb | 2024-09-28 15:19:00 | 2024-09-28 15:19:05 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
const int MAXN=100010;
const int INF=1e9;
int n;
char ch[MAXN];
int col[MAXN];
int cnt[MAXN];
int ans[MAXN];
vector<int> T[MAXN];
priority_queue<int> pq[MAXN];
void dfs(int u){
if(!T[u].size()){
if(col[u])pq[u].push(1);
else pq[u].push(-1);
return;
}
bool flag=false;
for(auto v: T[u]){
dfs(v);
cnt[u]+=cnt[v];
if(!flag){
swap(pq[u],pq[v]);
flag=true;
ans[u]=ans[v];
continue;
}
static int tmp[MAXN];
int len=min(pq[u].size(),pq[v].size());
int sum=0;
for(int i=0;i<len;++i){
tmp[i]=pq[u].top()+pq[v].top();
pq[u].pop(),pq[v].pop();
}
while(!pq[u].empty())pq[u].pop();
for(int i=0;i<len;++i){
pq[u].push(tmp[i]);
if(tmp[i]>0)sum+=tmp[i];
tmp[i]=0;
}
if(v==T[u].back()){
ans[u]=cnt[u]-sum;
// cout<<u<<":::"<<cnt[u]<<' '<<sum<<endl;
}
}
if(col[u])pq[u].push(1),ans[u]-=(T[u].size()>1);
else pq[u].push(-1);
priority_queue<int> tmp;
tmp=pq[u];
// cout<<u<<":"<<cnt[u]<<endl;
// while(!tmp.empty())cout<<-tmp.top()<<' ',tmp.pop();
// cout<<endl;
}
int main(){
int testcase;
scanf("%d",&testcase);
while(testcase--){
scanf("%d",&n);
scanf("%s",ch+1);
for(int i=1;i<=n;++i){
col[i]=ch[i]-'0';
cnt[i]=col[i];
}
for(int i=2;i<=n;++i){
int p;
scanf("%d",&p);
T[p].push_back(i);
}
dfs(1);
for(int i=1;i<=n;++i){
printf("%d",ans[i]);
if(i<n)putchar(' ');
}
putchar('\n');
for(int i=1;i<=n;++i){
T[i].clear();
cnt[i]=col[i]=ans[i]=0;
while(!pq[i].empty())pq[i].pop();
}
}
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 2ms
memory: 9472kb
input:
2 9 101011110 1 1 3 3 3 6 2 2 4 1011 1 1 3
output:
4 1 2 0 0 0 0 0 0 2 0 0 0
result:
ok 2 lines
Test #2:
score: 0
Accepted
time: 1179ms
memory: 33040kb
input:
6107 12 000000001000 1 2 3 2 5 4 4 7 3 8 11 19 1100111101111011110 1 2 1 1 4 5 2 4 3 2 2 7 10 2 11 3 15 5 7 0111110 1 1 2 2 1 5 3 000 1 1 7 1000011 1 2 3 3 5 4 7 0001001 1 1 1 3 5 3 8 00111000 1 1 3 2 5 2 7 11 11111110111 1 1 1 4 5 4 5 2 5 1 15 110101101000010 1 2 3 2 1 5 2 5 6 5 8 7 9 14 10 0101000...
output:
1 1 1 1 0 0 0 0 0 0 0 0 6 2 0 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 2 0 1 0 0 0 0 2 1 0 0 0 0 0 0 4 0 0 2 1 0 0 0 0 0 0 4 3 0 0 2 0 0 0 0 0 0 0 0 0 0 2 0 1 0 0 0 0 0 0 0 6 5 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 1 1 0 0 0 5 1 0 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 5 3 ...
result:
ok 6107 lines
Test #3:
score: 0
Accepted
time: 201ms
memory: 16908kb
input:
10 100000 10001010000001100001000100001000010100010101100001001110110001000010000110001000000010000011000001000001010001110100000000000000000010011011100000000000001000000000100100100110000000100001010011000000110000000111010100100001100000100100101001000000010000000011100000000000000010001100011100...
output:
22440 21414 19422 13454 5328 2719 1421 1168 1478 661 4662 5037 418 183 2304 501 2008 1643 692 2211 570 1003 967 950 504 124 894 333 775 523 905 197 12 337 195 310 1325 1016 638 50 907 361 179 336 313 102 309 555 733 871 490 414 375 318 66 625 336 267 276 162 203 25 112 216 252 146 42 233 232 333 27 ...
result:
ok 10 lines
Test #4:
score: 0
Accepted
time: 96ms
memory: 13860kb
input:
10 100000 01010111111101011100011111111010011001111111110001100111111101011111110011101111110110111011010111011011010011111110101111111011111111011101011111011001110101111011011010110100011111001101001011111101111101111111111100101101000111111110111101111111111011111100111011101110110101111010101101...
output:
25019 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ...
result:
ok 10 lines
Test #5:
score: -100
Time Limit Exceeded
input:
10 100000 00111110110011111111111010011111011111101010110111111110011110111111111111000110101110110111111101011111111111010101111111011001110110011101111001110111101101110110101000011111110100101110110100111110001111011100111101011010111111011011100011111011110111111110011110111111001111111010011100...
output:
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ...