#include <iostream>
using namespace std;
//十进制转二进制
void bin(int a[],int m){
for (int i = 15; i >= 0; i--){ //从数组最后一位开始存,正序输出数组就是正确的二进制
a[i] = m%2;
m = m/2;
}
}
//循环左移
void LeftMove(int a[]){
int temp = a[0];
for (int j = 0; j < 15; j++){//下标0~14的每一位都变成后一位的值
a[j] = a[j+1];
}
a[15] = temp;//最后一位是上一次的首位
}
int main() {
int m,n;
int i,j = 15;
while (cin >> m >> n) { // 注意 while 处理多个 case
int *a = new int[16]; //存放m的二进制
int *b = new int[16]; //存放n的二进制
//十进制转二进制
bin(a,m);
bin(b,n);
do {
bool flag = false;
for (i = 0; i < 16; i++){ //对比每一位是否相同
if (a[i] != b[i]){
flag = false;
LeftMove(a);
break;
}
else flag = true;
}
if (flag){
cout<<"YES"<<endl;
break;
}
j--;
}while (j);
if (j==0)
cout<<"NO"<<endl;
}
}
// 64 位输出请用 printf("%lld")