#include <iostream>
#include <algorithm>
#include <stdio.h>
#include <set>
#include <vector>
#include <map>
#include <tuple>
#include <deque>
#include <string.h>
using namespace std;
#define LL long long
char dccin[100100];
//bool odw[100100];
char dccout[100100];
LL n;
bool dccinbad()
{
for(int i=0;i<n;i++)
{
// printf("dccinbad: %d: %d %d\n",i, dccin[i],dccin[0]);
if(dccin[i]!=dccin[0])return false;
}
return true;
}
bool dccoutbad(const map<LL,vector<LL>>&w)
{
for(auto [i,v] : w)
{
for(auto itv : v)
{
if(dccout[i]==dccout[itv])return false;
}
}
return true;
}
int main() {
LL t;
scanf("%lld",&t);
while(t--)
{
LL a,b;
char c;
scanf("%lld\n%s\n%s\n",&n,dccin,dccout);
//printf("%lld\n%s\n%s\n",n,dccin,dccout);
map<LL,vector<LL>>w;
for(int i=0;i<n-1;i++)
{
scanf("%lld %lld",&a,&b);
w[a-1].push_back(b-1);
w[b-1].push_back(a-1);
}
if(strcmp(dccin,dccout)==0)printf("TAK\n");
else if(dccinbad())printf("NIE\n");
else if(dccoutbad(w))printf("NIE\n");
else printf("TAK\n");
}
return 0;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 | #include <iostream> #include <algorithm> #include <stdio.h> #include <set> #include <vector> #include <map> #include <tuple> #include <deque> #include <string.h> using namespace std; #define LL long long char dccin[100100]; //bool odw[100100]; char dccout[100100]; LL n; bool dccinbad() { for(int i=0;i<n;i++) { // printf("dccinbad: %d: %d %d\n",i, dccin[i],dccin[0]); if(dccin[i]!=dccin[0])return false; } return true; } bool dccoutbad(const map<LL,vector<LL>>&w) { for(auto [i,v] : w) { for(auto itv : v) { if(dccout[i]==dccout[itv])return false; } } return true; } int main() { LL t; scanf("%lld",&t); while(t--) { LL a,b; char c; scanf("%lld\n%s\n%s\n",&n,dccin,dccout); //printf("%lld\n%s\n%s\n",n,dccin,dccout); map<LL,vector<LL>>w; for(int i=0;i<n-1;i++) { scanf("%lld %lld",&a,&b); w[a-1].push_back(b-1); w[b-1].push_back(a-1); } if(strcmp(dccin,dccout)==0)printf("TAK\n"); else if(dccinbad())printf("NIE\n"); else if(dccoutbad(w))printf("NIE\n"); else printf("TAK\n"); } return 0; } |
English