結果
| 問題 | 
                            No.1242 高橋君とすごろく
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2020-10-08 14:22:59 | 
| 言語 | C++14  (gcc 13.3.0 + boost 1.87.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 3 ms / 2,000 ms | 
| コード長 | 1,045 bytes | 
| コンパイル時間 | 2,210 ms | 
| コンパイル使用メモリ | 190,564 KB | 
| 実行使用メモリ | 5,376 KB | 
| 最終ジャッジ日時 | 2024-07-20 05:53:42 | 
| 合計ジャッジ時間 | 3,490 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 4 | 
| other | AC * 24 | 
ソースコード
#pragma GCC optimize("Ofast", "unroll-loops")
#include <bits/stdc++.h>
using namespace std;
#define ll long long
ll N; int K;
vector<ll> A;
map<ll, int> isNG;
void input(void){
    cin >> N >> K;
    A.resize(K);
    for (int i = 0; i < K; ++i){
        cin >> A[i];
        isNG[A[i]] = 1;
    }
}
bool NG_check1(void){
    for (int i = 0; i < K; ++i){
        if (
            (A[i] >= 10 && isNG[A[i] + 5]) ||
            (A[i] >= 11 && isNG[A[i] + 3]) ||
            (A[i] >= 12 && isNG[A[i] + 1])
        )
            return true;
    }
    return false;
}
void small_simulate(void){
    constexpr int R = 10;
    for (int i = R; i >= 0; --i){
        if (
            (isNG[i + 1] && isNG[i + 6]) ||
            (isNG[i + 2] && isNG[i + 5]) ||
            (isNG[i + 3] && isNG[i + 4])
        )
            isNG[i] = 1;
    }
}
bool NG_check2(void){
    small_simulate();
    return isNG[1];
}
int main(void){
    input();
    if (NG_check1() || NG_check2()) cout << "No" << endl;
    else cout << "Yes" << endl;
    return 0;
}