1 条题解

  • 0
    @ 2026-4-2 15:35:57

    Kevin and Combination Lock 题解

    题意简述

    给定一个整数 xx,你可以执行以下两种操作任意次:

    1. x33x\neq 33,可以删除 xx连续的两个数字 33
    2. x33x\ge 33,可以令 x=x33x=x-33

    问能否通过若干次操作使得 xx 变为 00


    核心观察

    两种操作本质上都在做同一件事: xx 减少 3333 的整数倍。

    • 操作 2 是直接减 3333,显然是 3333 的倍数。
    • 操作 1 删除数字串中的 "33",等价于原数减去形如 33k000\underbrace{33}_{k个0}\cdots00 的数,也一定是 3333 的倍数。

    因此: 能把 xx 变成 00,当且仅当 xx3333 的倍数。


    结论

    对每个 xx

    • xmod33=0x \bmod 33 = 0,输出 YES
    • 否则输出 NO

    完整 AC 代码

    #include <iostream>
    using namespace std;
    
    int main() {
        ios::sync_with_stdio(false);
        cin.tie(nullptr);
        
        int t;
        cin >> t;
        while (t--) {
            long long x;
            cin >> x;
            cout << (x % 33 == 0 ? "YES" : "NO") << '\n';
        }
        return 0;
    }
    

    复杂度分析

    • 时间复杂度:O(t)O(t),每组数据 O(1)O(1) 判断。
    • 空间复杂度:O(1)O(1)
    • 数据范围 t104,x109t\le 10^4, x\le 10^9,完全满足时限要求。
    • 1

    信息

    ID
    6228
    时间
    1000ms
    内存
    256MiB
    难度
    10
    标签
    递交数
    1
    已通过
    1
    上传者