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

using namespace std;

int main()
{
    int t,k;
    int tab[]={1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987,
    1597, 2584, 4181, 6765, 10946, 17711, 28657, 46368, 75025, 121393, 196418,
    317811, 514229, 832040, 1346269, 2178309, 3524578, 5702887, 9227465, 14930352,
    24157817, 39088169, 63245986};
    long long suma, w1, w2;
    cin >> t;
    for(int i=0; i<t; i++)
    {
        cin >> k;
        suma=0;
        w1=0;
        w2=37;
        while(w1!=w2)
        {
            suma=tab[w1]*tab[w2];
            if( suma<k)w1++;
            else if(suma>k)w2--;
            else break;
            //cout << suma << " " << tab[w1] << " " << tab[w2] << endl;
        }
        if(w1!=w2)cout << "TAK" << endl;
        else if(w1==w2 && tab[w1]*tab[w2]==k)cout << "TAK" << endl;
        else cout << "NIE" << endl;
    }
}