#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; } |
English