/ SeriousOJ /

Record Detail

Accepted


  
# Status Time Cost Memory Cost
#1 Accepted 1ms 284.0 KiB
#2 Accepted 1ms 540.0 KiB
#3 Accepted 2ms 500.0 KiB
#4 Accepted 2ms 488.0 KiB
#5 Accepted 51ms 1.09 MiB
#6 Accepted 50ms 1.098 MiB
#7 Accepted 637ms 6.953 MiB
#8 Accepted 626ms 6.953 MiB
#9 Accepted 629ms 7.012 MiB
#10 Accepted 328ms 5.551 MiB

Code

#include<bits/stdc++.h>
// #include "atnh.h"
using namespace std;

int main()
{
	// fio();

	int t,cs=0; cin>>t;
	while(t--){
		int n,q; cin>>n>>q;
		bool a[n+1]={};
		for(int i=1;i<=n;i++){
			cin>>a[i];
		}
		
		vector<int>g[n+1];
		for(int i=0;i<n-1;i++){
			int u,v; cin>>u>>v;
			g[u].push_back(v); g[v].push_back(u);
		}

		bool c[n+1] = {};
		for(int i=0;i<q;i++){
			int x; cin>>x;
			c[x]^=1;
		}
		
		function<void(int,int)>f=[&](int s, int p)
		{
			if(p!=-1) c[s]^=c[p];
			for(auto to:g[s]){
				if(to^p){
					f(to,s);
				}
			}
		};

		f(1,-1);
		
		cout<<"Case "<<++cs<<":";
		for(int i=1;i<=n;i++){
			cout<<' '<<(a[i]^c[i]);
		} cout<<endl;
	}
    return 0;
}

Information

Submit By
Type
Submission
Problem
P1003 Tahsin and Tree
Language
C++17 (G++ 13.2.0)
Submit At
2023-11-29 20:53:46
Judged At
2023-12-21 05:48:56
Judged By
Score
100
Total Time
637ms
Peak Memory
7.012 MiB