1 条题解

  • 1
    @ 2021-8-29 14:43:21

    这道题扎心了。各种优化,dfs在自己电脑最快跑1.2秒。加上标签是递归,找了一天的规律,也总结不出个递归的公式。走投无路提交服务器试了试,dfs0.2秒。。。白瞎折腾了。

    #include <bits/stdc++.h>
    using namespace std;
    int res = 0, n, masks[15];
    bool OK(long long x, int len) {
        if (len < 3) return true;
        for (int check_length = 1; check_length <= len / 3; ++check_length) {
            register long long temp = x >> (len - check_length * 3);
            register int mask = masks[check_length];
            unsigned int a1 = temp & mask, a2 = (temp >> check_length)&mask, a3 = (temp >> check_length) >> check_length;
            if (a1 == a2 and a3 == a2) return false;
        }
        return true;
    }
    void dfs(long long x, int index) {
        if (index >= n) res++;
        else {
            if (OK(x, index + 1)) dfs(x, index + 1);
            x |= (1LL << index);
            if (OK(x, index + 1)) dfs(x, index + 1);
        }
    }
    int main() {
        for (int i = 1; i < 15; ++i) masks[i] = (1 << i) - 1;
        cin >> n;
        dfs(0LL, 0);
        cout << res;
    }
    
    • 1

    信息

    ID
    820
    时间
    1000ms
    内存
    16MiB
    难度
    4
    标签
    递交数
    39
    已通过
    21
    上传者