| 12
 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
 
 | #include<bits/stdc++.h>
 using namespace std;
 typedef long long ll;
 const int N=1e5+10;
 int a[30]={10,11,100,101,110,
 111,1000,1001,1010,1011,
 1100,1101,1110,1111,10000,
 10001,10010,10011,10100,10101,
 10110,10111,11000,11001,11010,
 11011,11100,11101,11110,11111};
 int main()
 {
 ios::sync_with_stdio(false);
 cin.tie(nullptr);
 int t;
 cin >> t;
 while(t--)
 {
 int n;
 cin >> n;
 bool flag=false;
 if(n==1)
 flag= true;
 else
 {
 for(int i=29;i>=0&&n>1;i--)
 {
 if(n%a[i]==0)
 {
 flag=true;
 n=n/a[i];
 i=29;
 }
 else
 flag= false;
 }
 }
 if(flag)
 cout << "YES\n";
 else
 cout << "NO\n";
 }
 return 0;
 }
 
 |