結果

問題 No.653 E869120 and Lucky Numbers
ユーザー 梧桐
提出日時 2025-09-26 17:26:55
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
WA  
実行時間 -
コード長 1,143 bytes
コンパイル時間 934 ms
コンパイル使用メモリ 74,456 KB
実行使用メモリ 7,848 KB
最終ジャッジ日時 2025-09-26 17:26:58
合計ジャッジ時間 2,211 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample WA * 3
other WA * 31
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:49:10: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   49 |     scanf("%d", &t);
      |     ~~~~~^~~~~~~~~~

ソースコード

diff #

#include <iostream>
#include <vector>

using namespace std;

void Solve() {
    string p;
    cin >> p;

    int len = p.size();
    vector<int> vec;
    vec.reserve(len);
    for (int i = len - 1; i >= 0; --i) vec.push_back(p[i] - '0');

    bool single = false;
    for (int i = 0; i < len; ++i) {
        if (i == len - 1) {
            if ((i != 0 && vec[i] == 0) || vec[i] == 6 || vec[i] == 7) {
                puts("Yes");
            } else {
                puts("No");
            }
            return;
        }
        if (single) {
            if (vec[i] != 6 && vec[i] != 7) {
                puts("No");
                return;
            }
        }
        if (vec[i] == 2) { // 6 + 6
            --vec[i + 1];
        } else if (vec[i] == 3) { // 6 + 7
            --vec[i + 1];
        } else if (vec[i] == 4) { // 7 + 7
            --vec[i + 1];
        } else if (vec[i] == 6) {
            single = true;
        } else if (vec[i] == 7) {
            single = true;
        } else {
            puts("No");
            return;
        }
    }
}

int main() {    int t;
    scanf("%d", &t);
    Solve();

    return 0;
}
0