QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#490268#6160. 树kymmykym#40 730ms310356kbC++172.4kb2024-07-25 13:49:292024-07-25 13:49:30

Judging History

你现在查看的是最新测评结果

  • [2024-07-25 13:49:30]
  • 评测
  • 测评结果:40
  • 用时:730ms
  • 内存:310356kb
  • [2024-07-25 13:49:29]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
int n;
const int maxn=525015;
int A[maxn],par[maxn];
vector<int>child[maxn];
const int LG = 21;
const int SLG=10;
int pre[LG][maxn];
bitset<(1<<(SLG))>B[maxn][SLG+1];
long long out;
typedef pair<int,int>pi;
vector<pi>update[maxn];
int twok[maxn][21];
int dep[maxn];
void predfs(int x, int p, int lvl){
	twok[x][0]=p;
	dep[x]=lvl;
	for(int i=1;i<=20;i++){
		if(twok[x][i-1] == -1)continue;
		twok[x][i] = twok[twok[x][i-1]][i-1];
	}
	for(auto v:child[x])if(v!=p){
		predfs(v,x,lvl+1);
	}
}
int lift(int x, int dd){
	for(int i=0;i<=20;i++){
		if(x==-1)return -1;
		if(dd&(1<<i))x=twok[x][i];
	}
	return x;
}

void dfs(int i){
	for(auto v:child[i])dfs(v);
	for(int bit = SLG; bit<LG;bit++){ // just jump
		int curt = A[i] % (1<<(bit+1));
		if(curt>=1<<bit){
			pre[bit][i]++;
		} else{
			int to=lift(i, ((1<<bit)-curt));
			if(to != -1){
				pre[bit][to]++;
			}
		}
		int idx = lift(i, ((1<<(bit+1)) - curt));
		if(idx!=-1)pre[bit][idx]--;
		while(idx != -1){
			int l = lift(idx, 1<<bit);
			if(l != -1)pre[bit][l]++;
			int l2 = lift(idx, 1<<(bit+1));
			if(l2 != -1)pre[bit][l2]++;
			idx=lift(idx,1<<(bit+1));
		}
	}	
	
	for(int bit=0;bit<SLG;bit++){
		int T = (1<<(bit+1));
		int curt = A[i] % T;
		if(curt>=1<<bit){
			pre[bit][i]++;
		} else{
			int to=lift(i, ((1<<bit)-curt));
			if(to != -1){
				pre[bit][to]++;
			}
		}
		int idx = lift(i, ((1<<(bit+1)) - curt));
		if(idx!=-1)update[idx].push_back({bit,dep[idx]%T});
		
	}
	
	for(auto x:update[i]){
		B[i][x.first][x.second]=1-B[i][x.first][x.second];
	}
	for(auto c:child[i]){
		
		//merge B[i] with Bx
		for(int bit=0;bit<SLG;bit++){
			B[i][bit] ^= B[c][bit];
		}
	}
	
	for(int bit=0;bit<LG;bit++){
		for(auto x:child[i]){
			pre[bit][i]+=pre[bit][x];
		}
	}
	int ans=0;
	for(int bit = 0; bit<LG;bit++){
		int T = (1<<(bit+1));	
		
		if(bit<SLG){
			int diff=0;
			
			diff -= B[i][bit][dep[i]%T];
			if(dep[i]%T >= T/2)diff += B[i][bit][dep[i]%T - T/2];
			else diff += B[i][bit][dep[i]%T + T/2];
		
			pre[bit][i] += diff;
		} else{
			
		}

	}
	for(int bit=0;bit<LG;bit++){
		int on = pre[bit][i] % 2;
		if(on){
			ans += 1<<bit;
		}
	}

	out += ans;
}

int32_t main(){
	cin >> n;
	for(int i=1;i<=n;i++)cin>>A[i];
	for(int i=2;i<=n;i++){
		cin>>par[i];
		child[par[i]].push_back(i);
	}
	memset(twok,-1,sizeof twok);
	predfs(1,-1,0);
	dfs(1);
	cout<<out;
		
}


詳細信息


Pretests


Final Tests

Test #1:

score: 5
Accepted
time: 12ms
memory: 102256kb

input:

1501
524935 524911 524956 524964 525002 524945 524944 524954 524980 525009 524971 524989 524955 524962 524933 524935 524938 524973 524931 524933 524939 524994 524948 524912 27768 524937 482489 525001 524961 524964 524988 524959 524984 43791 525005 524911 524929 524952 524944 524918 524924 524961 524...

output:

701627312

result:

ok 1 number(s): "701627312"

Test #2:

score: 5
Accepted
time: 15ms
memory: 104912kb

input:

2501
524935 524987 524985 15371 521077 524914 358211 524917 524933 524940 524997 524965 525010 508291 509667 525010 34977 524932 525001 524931 524927 524931 524942 524978 524940 524999 48818 524991 524942 524983 524953 524952 524932 524911 524996 524980 524926 524978 524988 524930 524951 524933 5249...

output:

1248760886

result:

ok 1 number(s): "1248760886"

Test #3:

score: 5
Accepted
time: 375ms
memory: 240600kb

input:

100000
524940 524940 524924 524939 524984 524915 524961 524980 525007 524983 525000 524949 525003 183887 203283 524986 524948 524943 524962 524962 524951 524938 524971 524944 524978 353146 524954 288731 524914 524927 524930 524964 524939 524977 524968 524937 524930 524931 525005 524917 524935 524953...

output:

48847009165

result:

ok 1 number(s): "48847009165"

Test #4:

score: 5
Accepted
time: 360ms
memory: 239920kb

input:

100000
525001 524945 300466 524918 524993 524942 524980 524940 524958 524982 524985 524930 525000 524914 524979 524916 524986 524952 524991 525010 524943 525003 404403 363004 524963 524999 524937 524940 307161 524926 524982 524988 524916 524987 524960 524993 524969 524946 524933 524951 524941 524920...

output:

48821541653

result:

ok 1 number(s): "48821541653"

Test #5:

score: 5
Accepted
time: 360ms
memory: 241416kb

input:

100000
524983 525002 524939 524914 524941 29526 73021 524953 524927 525007 524993 524982 524976 524975 524981 524950 524970 524937 524980 524916 524979 524983 55981 524985 524975 524969 524982 524921 524985 459301 525008 524911 524932 524954 524952 524952 524959 306535 524989 524989 524987 524951 52...

output:

48815029002

result:

ok 1 number(s): "48815029002"

Test #6:

score: 5
Accepted
time: 727ms
memory: 309736kb

input:

152501
524982 524933 525002 524967 82725 253741 524911 524981 524972 524935 244289 524931 524957 524927 524940 524960 524932 150931 524974 524920 524975 524940 525008 524963 71995 525001 524997 524974 69275 146625 459556 524968 524919 447791 524928 524983 524953 524963 524959 524985 524999 249653 52...

output:

74328889396

result:

ok 1 number(s): "74328889396"

Test #7:

score: 5
Accepted
time: 730ms
memory: 309104kb

input:

152501
524970 524966 524938 524994 525004 524921 188941 525008 524943 524917 524999 524997 284880 524976 524946 524994 524976 524923 524960 524990 524917 525005 524987 524961 525009 254221 524982 108142 524971 524988 524927 524915 524983 524961 524951 524988 524985 525001 524936 524921 524973 524949...

output:

74602741206

result:

ok 1 number(s): "74602741206"

Test #8:

score: 5
Accepted
time: 691ms
memory: 310356kb

input:

152501
524980 524993 525005 524943 524950 524998 524990 524952 261512 524968 524918 524973 524976 524920 524951 524952 524965 524966 524914 524976 524937 524917 524914 524911 524991 524997 524974 524964 524945 524941 524920 524916 524971 192185 524971 524926 524959 524971 524973 524911 524921 524997...

output:

74603663049

result:

ok 1 number(s): "74603663049"

Test #9:

score: 0
Time Limit Exceeded

input:

525010
524955 524979 495345 524927 524966 524997 524942 138576 524956 524989 524940 524969 360541 524997 524952 524997 524933 524931 524958 524987 524933 524941 407091 524952 524951 524972 524998 524913 524955 524948 524988 524920 524981 524999 524985 525002 524940 524976 524956 524920 524921 524978...

output:


result:


Test #10:

score: 0
Time Limit Exceeded

input:

525010
410691 524927 524994 524983 524994 524996 524933 524973 525009 331627 524951 524998 171113 524978 524960 525000 69833 524948 525002 524919 525001 294363 524925 263273 116049 524946 524993 524976 524961 524936 524968 7337 524987 524981 524925 260013 524931 427126 524993 524962 524950 524956 52...

output:


result:


Test #11:

score: 0
Time Limit Exceeded

input:

525010
524949 524945 524932 524948 524918 524939 524958 524963 524923 524995 524981 524950 524927 524929 524945 524972 524911 524961 524913 524949 524986 524934 524971 524925 524950 524957 524919 524945 524982 524929 524982 524926 524938 331619 524965 524934 524929 524949 524917 524978 337295 524919...

output:


result:


Test #12:

score: 0
Time Limit Exceeded

input:

525010
524926 524992 524936 524979 524925 524994 525001 524946 524981 524922 524993 436287 525002 524939 525007 524926 524986 524975 524986 524961 524932 525007 524935 524948 524988 524972 524963 524956 524960 38337 524932 524924 524996 524955 524986 524976 524966 524973 524983 524991 524965 524978 ...

output:


result:


Test #13:

score: 0
Time Limit Exceeded

input:

525010
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

output:


result:


Test #14:

score: 0
Time Limit Exceeded

input:

525010
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

output:


result:


Test #15:

score: 0
Time Limit Exceeded

input:

525010
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

output:


result:


Test #16:

score: 0
Time Limit Exceeded

input:

525010
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

output:


result:


Test #17:

score: 0
Time Limit Exceeded

input:

525010
524997 524962 524959 525010 524997 524946 524992 524974 524978 524988 524983 524960 524949 524922 524948 524925 179739 374866 524976 113487 524978 524936 524931 524912 524993 524933 524947 524940 524947 524949 525008 525006 524928 524979 524966 524925 524993 524917 524915 524969 524997 524936...

output:


result:


Test #18:

score: 0
Time Limit Exceeded

input:

525010
524939 524971 524960 524991 524958 524977 525000 524920 524937 524925 524933 524944 524977 524921 524975 524942 524933 524998 524913 524938 524937 524980 525004 524986 15097 20701 524986 525008 524943 258327 525008 524982 524925 524956 439611 524955 42646 46145 525009 524957 524961 524946 524...

output:


result:


Test #19:

score: 0
Time Limit Exceeded

input:

525010
524913 524930 525002 524948 524945 524933 524990 524998 525001 524995 524974 524912 524950 524951 524951 524960 524928 524927 524911 350625 524991 178441 300871 524988 524982 524949 325161 524957 524999 332281 525005 524913 524960 524998 525006 199811 525008 524960 338801 524944 524953 524935...

output:


result:


Test #20:

score: 0
Time Limit Exceeded

input:

525010
524951 524981 524977 524964 524942 524945 524936 524994 524959 524920 524971 524979 524945 365305 524992 524945 525001 524979 524951 524951 524994 524955 524975 524937 524939 524913 524963 524960 524977 524949 524970 524995 524978 524989 524912 524933 524998 524999 524992 524983 524956 156707...

output:


result: