#include<iostream> #include<stdint.h> #include<vector> using namespace std; vector<int> fib; // sprawdzanie z tresci zadania bool check(int x) { for(int i=0;i<fib.size();++i){ if(x%fib[i]!=0) continue; // szukam pierwszego dzielnika, jezeli sie nie dzieli, to pomijamy int t=x/fib[i]; // reszta if(t==1) return true; for(int j=0;j<fib.size();++j) { if(t==fib[j]) return true; } } return false; } int main(int argc, char** argv) { std::ios::sync_with_stdio(false); // dodaje 2 elementy wieksze o 1 fib.push_back(2); fib.push_back(3); // obliczam pozostale, ktore sa mniejsze lub rowne 10^9 for(;;) { int v=fib[fib.size()-1]+fib[fib.size()-2]; if(v>1000000000) break; fib.push_back(v); } int t; cin>>t; for(int i=0;i<t;++i) { int x; cin>>x; cout<<(check(x)?"TAK":"NIE")<<endl; } 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 | #include<iostream> #include<stdint.h> #include<vector> using namespace std; vector<int> fib; // sprawdzanie z tresci zadania bool check(int x) { for(int i=0;i<fib.size();++i){ if(x%fib[i]!=0) continue; // szukam pierwszego dzielnika, jezeli sie nie dzieli, to pomijamy int t=x/fib[i]; // reszta if(t==1) return true; for(int j=0;j<fib.size();++j) { if(t==fib[j]) return true; } } return false; } int main(int argc, char** argv) { std::ios::sync_with_stdio(false); // dodaje 2 elementy wieksze o 1 fib.push_back(2); fib.push_back(3); // obliczam pozostale, ktore sa mniejsze lub rowne 10^9 for(;;) { int v=fib[fib.size()-1]+fib[fib.size()-2]; if(v>1000000000) break; fib.push_back(v); } int t; cin>>t; for(int i=0;i<t;++i) { int x; cin>>x; cout<<(check(x)?"TAK":"NIE")<<endl; } return 0; } |