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
#include <cstdio>

using namespace std;

const int NMAX = 300 * 1000 + 7;

int n;
char fst[NMAX] = {0};
char snd[NMAX] = {0};

int roz_odd[27], roz_even[27];


int main() {
	(void)! scanf("%d %s %s", &n, fst, snd);

	for (int i = 0; i < n; i++)
	{
		if (i % 2 == 0)
			roz_odd[fst[i] - 'a']++;
		else
			roz_even[fst[i] - 'a']++;
	}

	for (int i = 0; i < n; i++)
	{
		if (i % 2 == 0)
			roz_odd[snd[i] - 'a']--;
		else
			roz_even[snd[i] - 'a']--;
	}

	for (int i = 0; i < 26; i++) {
	//	printf("%c %d %d\n", (char) i + 'a', roz_odd[i], roz_even[i]);
		if(roz_odd[i] != 0 || roz_even[i] != 0) {
			printf("NIE\n");
			return 0;
		}
	}

	printf("TAK\n");
	return 0;
}