QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#461668#5017. 相等树链Iratis10 181ms390544kbC++144.9kb2024-07-02 22:00:062024-07-02 22:00:06

Judging History

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

  • [2024-07-02 22:00:06]
  • 评测
  • 测评结果:10
  • 用时:181ms
  • 内存:390544kb
  • [2024-07-02 22:00:06]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
#define ll long long
// #define int long long
#define md(a) a=(a%mod+mod)%mod
#define file(a) freopen(#a".in","r",stdin);freopen(#a".out","w",stdout)

bool ST;

const int N=200005,inf=1e9;ll ans=0;
int n;ll val[N];vector<int>soa[N],sob[N];

struct Random {
	mt19937_64 rnd;
	Random():rnd(chrono::high_resolution_clock::now().time_since_epoch().count()) {}
	ll next(ll l,ll r) {
		return uniform_int_distribution<ll>(l,r)(rnd);
	}
} rnd;

inline void ad1(int x,int y){soa[x].push_back(y);}inline void zc1(int x,int y){ad1(x,y),ad1(y,x);}
inline void ad2(int x,int y){sob[x].push_back(y);}inline void zc2(int x,int y){ad2(x,y),ad2(y,x);}

int rt,sz[N];bool vst[N];
void Grt(int x,int fa,int siz)
{
	sz[x]=1;int mx=0;
	for(int y:soa[x])if(y!=fa&&!vst[y])Grt(y,x,siz),sz[x]+=sz[y],mx=max(mx,sz[y]);
	mx=max(mx,siz-sz[x]);if(mx*2<=siz)rt=x;
}
void Gsz(int x,int fa){sz[x]=1;for(int y:soa[x])if(y!=fa&&!vst[y])Gsz(y,x),sz[x]+=sz[y];}
vector<int>inc,ic[N];ll sa[N],sb[N];int dep[N],bl[N];bool tag[N],on[N];int mx[N],mx2[N];
void dfs1(int x,int fa,int up)
{
	inc.push_back(x);if(up)ic[up].push_back(x);tag[x]=1;sa[x]=sa[fa]^val[x];if(!fa)sa[x]=0;
	for(int y:soa[x])if(y!=fa&&!vst[y])dfs1(y,x,(up?up:y));
}
void dfs2(int x,int fa,int up,int d)
{
	on[x]=1;sb[x]=sb[fa]^val[x];bl[x]=up;dep[x]=d;assert(sb[x]>=0);
	for(int y:sob[x])if(y!=fa&&tag[y])dfs2(y,x,(up?up:y),d+1);
}
void pre_dfs(int x,int fa)
{
	for(int y:soa[x])if(y!=fa&&!vst[y])
	{
		mx[y]=mx[x],mx2[y]=mx2[x];
		if(dep[y]>=dep[mx[y]])
		{
			if(bl[y]!=bl[mx[y]])mx2[y]=mx[y];
			mx[y]=y;
		}
		else if(dep[y]>=dep[mx2[y]]&&bl[y]!=bl[mx[y]])mx2[y]=y;
		pre_dfs(y,x);
	}
}

namespace Self
{
	inline void main(int x)
	{
		// cout<<bl[2]<<' '<<bl[1]<<'\n';
		for(int y:inc)if(on[y])
		{
			// cout<<y<<' '<<mx[y]<<' '<<mx2[y]<<'\n';
			if(sa[y]==(sb[mx[y]]^sb[mx2[y]]))ans++;
		}
		// cout<<ans<<'\n';
	}
};

const int M=19491001;
struct HashInt
{
	int h[M],st[M],top;ll val[N*5];int f[N*5],nxt[N*5],tot;
	inline void clear(){while(top)h[st[top]]=0,top--;tot=0;}
	inline void ins(ll v)
	{
		assert(v>=0);
		int x=v%M;
		for(int k=h[x];k;k=nxt[k])if(val[k]==v){f[k]++;return ;}
		if(!h[x])st[++top]=x;tot++,val[tot]=v,f[tot]=1,nxt[tot]=h[x],h[x]=tot;
	}
	inline int ask(ll v)
	{
		assert(v>=0);
		int x=v%M;
		for(int k=h[x];k;k=nxt[k])if(val[k]==v)return f[k];
		return 0;
	}
}mp[2];
struct HashPair
{
	int h[M],st[M],top;pair<ll,int>val[N*5];int f[N*5],nxt[N*5],tot;
	inline void clear(){while(top)h[st[top]]=0,top--;tot=0;}
	inline void ins(pair<ll,int>v)
	{
		assert(v.first>=0);
		int x=(v.first%M+v.second*131)%M;
		for(int k=h[x];k;k=nxt[k])if(val[k]==v){f[k]++;return ;}
		if(!h[x])st[++top]=x;tot++,val[tot]=v,f[tot]=1,nxt[tot]=h[x],h[x]=tot;
	}
	inline int ask(pair<ll,int>v)
	{
		assert(v.first>=0);
		int x=(v.first%M+v.second*131)%M;
		for(int k=h[x];k;k=nxt[k])if(val[k]==v)return f[k];
		return 0;
	}
}m2[2];

namespace Tside
{
	inline void main(int x)
	{
		mp[0].clear(),mp[1].clear(),m2[0].clear(),m2[1].clear();
		for(int s:soa[x])if(!vst[s])
		{
			for(int y:ic[s])if(on[y])
			{
				ans+=mp[0].ask(sa[y]^sb[mx[y]])-m2[0].ask({sa[y]^sb[mx[y]],bl[mx[y]]});
				ans+=mp[1].ask(sa[y]^sb[mx[y]])-m2[1].ask({sa[y]^sb[mx[y]],bl[mx[y]]});
				ans+=mp[0].ask(sa[y]^sb[mx2[y]])-m2[0].ask({sa[y]^sb[mx2[y]],bl[mx2[y]]});
			}
			for(int y:ic[s])if(on[y])
			{
				mp[0].ins(sa[y]^sb[mx[y]]),m2[0].ins({sa[y]^sb[mx[y]],bl[mx[y]]});
				mp[1].ins(sa[y]^sb[mx2[y]]),m2[1].ins({sa[y]^sb[mx2[y]],bl[mx2[y]]});
			}
		}
		// cout<<ans<<'\n';
	}
};

namespace Oside
{
	inline void main(int x)
	{
		mp[0].clear();mp[1].clear();
		for(int s:soa[x])if(!vst[s])
		{
			// cout<<"chk:"<<s<<'\n';
			for(int y:ic[s])if(on[y])
			{
				if(mx2[y]!=x)ans+=mp[0].ask(sa[y]^sb[mx[y]]^sb[mx2[y]]);
				ans+=mp[1].ask(sa[y]);
			}
			for(int y:ic[s])if(on[y])
			{
				mp[0].ins(sa[y]);
				if(mx2[y]!=x)mp[1].ins(sa[y]^sb[mx[y]]^sb[mx2[y]]);
			}
		}
		// cout<<ans<<'\n';
	}
};

inline void calc(int x)
{
	// cout<<"calc:"<<x<<'\n';
	dfs1(x,0,0),dfs2(x,0,0,1),mx[x]=mx2[x]=x;pre_dfs(x,0);
	Self::main(x);Tside::main(x);Oside::main(x);
	for(int x:inc)tag[x]=on[x]=0;inc.clear();for(int y:soa[x])ic[y].clear();
}
void solve(int x)
{
	vst[x]=1,Gsz(x,0),calc(x);
	// return ;
	for(int y:soa[x]){if(!vst[y])Grt(y,x,sz[y]),solve(y);}
}

inline void solve()
{
	for(int i=1;i<=n;i++)soa[i].clear(),sob[i].clear(),vst[i]=0;ans=0;
	cin>>n;
	for(int i=2,x;i<=n;i++)cin>>x,zc1(x,i);for(int i=2,x;i<=n;i++)cin>>x,zc2(x,i);
	for(int i=1;i<=n;i++)val[i]=rnd.next(0,(1ll<<62)-1);Grt(1,0,n),solve(rt);cout<<ans<<'\n';
}

bool ED;

signed main()
{
	cerr<<(&ST-&ED)/1024.0/1024<<endl;ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
	// file(tree);
	int T=1;
	// cin>>T;
	while(T--)
	{
		solve();
	}
	return 0;
}

詳細信息

Subtask #1:

score: 10
Accepted

Test #1:

score: 10
Accepted
time: 126ms
memory: 352152kb

input:

5000
1296 1400 867 4533 1296 2007 2059 115 821 2960 3187 1597 2409 2708 4743 4778 1345 3967 911 3400 4249 3793 339 3145 3490 607 4148 3513 3264 3852 568 775 828 1348 423 3678 305 1938 1096 1373 2662 1048 4328 4208 203 779 3103 3372 4523 192 264 792 4943 2211 2494 3513 3555 4935 3277 3390 4624 128 18...

output:

76002

result:

ok 1 number(s): "76002"

Test #2:

score: 10
Accepted
time: 152ms
memory: 387476kb

input:

5000
1820 281 610 3735 3580 3994 2060 2424 3338 2859 281 532 1286 1771 825 3738 3793 2260 556 4068 3793 4169 4411 4941 122 4270 4711 524 4037 2508 50 3343 2030 1151 4002 533 2994 1440 1762 3851 3050 4470 555 1979 3178 3933 3793 281 4810 520 3793 3535 2526 4422 2859 1561 1544 649 4544 2882 1236 2749 ...

output:

604316

result:

ok 1 number(s): "604316"

Test #3:

score: 10
Accepted
time: 181ms
memory: 390544kb

input:

5000
4333 51 707 3055 3433 1451 1305 1431 3081 302 1633 88 2024 441 120 4650 3927 4970 2578 3170 4245 4204 2102 4954 3140 1039 360 3173 4203 4927 4437 4337 4502 1712 3598 2968 2 4884 1260 1768 585 1815 4346 2938 4638 4886 4482 1095 1452 298 2702 2257 1375 2819 4482 711 220 396 3907 4792 2798 4445 42...

output:

912032

result:

ok 1 number(s): "912032"

Test #4:

score: 10
Accepted
time: 119ms
memory: 384412kb

input:

5000
362 4710 4997 4405 4728 3964 4258 3568 4997 2924 2931 4997 1094 2174 2220 127 4739 260 2591 4130 4916 1614 1408 324 2924 3272 4997 4020 2924 4216 2924 2931 2924 4783 271 1101 2924 246 4953 2553 4588 2924 1770 3738 4617 2508 2486 2137 1348 4847 2632 596 1011 1442 1287 4665 2924 2203 4411 726 109...

output:

1176721

result:

ok 1 number(s): "1176721"

Test #5:

score: 10
Accepted
time: 175ms
memory: 382428kb

input:

5000
3579 3530 3328 388 4864 4954 4597 3600 2428 1610 4533 1797 427 1296 3595 3861 4703 2914 4194 3195 451 585 3600 1134 1649 470 2049 2843 2845 3473 26 845 484 3301 1929 1342 1937 2003 1543 832 2301 2543 1889 1211 1619 1937 4471 585 4440 3600 1398 4687 2931 3982 2334 589 388 4012 873 66 2406 3861 1...

output:

1226857

result:

ok 1 number(s): "1226857"

Subtask #2:

score: 0
Time Limit Exceeded

Test #6:

score: 0
Time Limit Exceeded

input:

200000
13177 40498 104798 83659 186055 32788 86489 72123 13521 134868 158968 60124 166316 163390 120935 103000 83938 57807 97940 40447 137723 154683 191864 59080 102808 3969 21451 165592 128776 49468 4101 26441 139317 59503 18053 118809 187783 149816 21609 98521 165692 52964 60425 23437 29614 106886...

output:


result:


Subtask #3:

score: 0
Skipped

Dependency #2:

0%

Subtask #4:

score: 0
Skipped

Dependency #1:

100%
Accepted

Dependency #2:

0%