#ifdef ONLINE_JUDGE #include #else #include #include #include #include #include #include #include #include #include #include #include #include #include #endif using namespace std; // lambda : [] (int a, int b) -> bool { body return } // string r_str = R"(raw string)" #define mp make_pair #define eb emplace_back #define pb push_back #define LL long long #define ULL unsigned long long #define BASE 73 #define NMAX 10000 #define NMAX2 20001 #define MOD1 1000000007 #define ALL(V) (V).begin(), (V).end() #define ALLR(V) (V).rbegin(), (V).rend() #define CRLINE Duxar(__LINE__); #define SHOWME(x) cerr << __LINE__ << ": " << #x << " = " << (x) << endl; #define ENTER putchar('\n'); void Duxar(int _this_line) { #ifndef ONLINE_JUDGE printf("\n . . . . . . . . . . . . . Passed line - %d\n", _this_line); #endif } template void ReadNo(T &_value) { T sign = 1; char ch; _value = 0; while(!isdigit(ch = getchar())) { (ch == '-') && (sign = -1); } do { _value = _value * 10 + (ch - '0'); } while(isdigit(ch = getchar())); _value *= sign; } template void AddNr(T &a, T b) { a = a + b; while (a >= MOD1) { a -= MOD1; } while (a < 0) { a += MOD1; } } int A, B; int main(){ #ifndef ONLINE_JUDGE freopen("input.cpp", "r", stdin); #endif int i, T; string S; ReadNo(T); while (T--) { cin >> S; sscanf(S.c_str(), "%d:%d", &A, &B); if (A >= 24 || B >= 60) { cout << "NO\n"; continue; } if (B == 0 || A == B || A + 22 == B || (A % 10 == B / 10 && A / 10 == B % 10) || A * 100 + B == 1024 || A * 100 + B == 2048) { cout << "YES\n"; } else { cout << "NO\n"; } } return 0; }