Codeforces 1579G DP / 二分 + bitset

题意

传送门 Codeforces 1579G Minimal Coverage

题解
DP

d p [ i + 1 ] [ j ] dp[i+1][j] dp[i+1][j] 代表 0 ⋯ i 0\cdots i 0⋯i 次移动后所在位置与覆盖区域最左侧位置相差 j j j 时,覆盖区域的最小值。枚举左右方向递推即可。总时间复杂度 O ( n ⋅ max ⁡ { a i } ) O(n\cdot\max\{a_i\}) O(n⋅max{ai})。

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
constexpr int M = 2E3, INF = 1e9;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int tt;
    cin >> tt;
    while (tt--) {
        int n;
        cin >> n;
        vector<int> a(n);
        for (int i = 0; i < n; ++i) {
            cin >> a[i];
        }
        auto _min = [](int &x, int y) {
            x = min(x, y);
        };
        vector<vector<int>> dp(n + 1, vector<int>(M, INF));
        dp[0][0] = 0;
        for (int i = 0; i < n; ++i) {
            for (int j = 0; j < M; ++j) {
                if (dp[i][j] == INF) {
                    continue;
                }
                if (j + a[i] < M) {
                    _min(dp[i + 1][j + a[i]], max(dp[i][j], j + a[i]));
                }
                if (j - a[i] >= 0) {
                    _min(dp[i + 1][j - a[i]], dp[i][j]);
                } else {
                    _min(dp[i + 1][0], dp[i][j] + a[i] - j);
                }
            }
        }
        int res = *min_element(dp[n].begin(), dp[n].end());
        cout << res << '\n';
    }

    return 0;
}
二分 + bitset

二分覆盖区域的大小 d d d。用 std::bitset 维护当前的可能位置,初始位置可能位于 [ 0 , d ) [0,d) [0,d) 中的任一个位置,递推即可。总时间复杂度 O ( n ⋅ max ⁡ { a i } ⋅ log ⁡ n / 32 ) O(n\cdot\max\{a_i\}\cdot\log n/32) O(n⋅max{ai}⋅logn/32)。

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
constexpr int N = 2E3;
using bt = bitset<N>;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int tt;
    cin >> tt;
    while (tt--) {
        int n;
        cin >> n;
        vector<int> a(n);
        for (int i = 0; i < n; ++i) {
            cin >> a[i];
        }
        auto judge = [&](int d) {
            bt x, mask;
            for (int i = 0; i < d; ++i) {
                x[i] = mask[i] = 1;
            }
            for (int i = 0; i < n; ++i) {
                x = ((x << a[i]) | (x >> a[i])) & mask;
            }
            return x.any();
        };
        int lb = 0, ub = N;
        while (ub - lb > 1) {
            int mid = (lb + ub) / 2;
            if (judge(mid)) {
                ub = mid;
            } else {
                lb = mid;
            }
        }
        cout << ub - 1 << '\n';
    }

    return 0;
}
相关推荐
Mr_Oak16 小时前
【multi-model】moco系列&SimCLR&BEiT
人工智能·深度学习·神经网络·算法·计算机视觉·transformer·对比学习
尼古拉斯·纯情暖男·天真·阿玮16 小时前
动态规划——子序列问题
java·算法·动态规划
立志成为大牛的小牛17 小时前
数据结构——四十、折半查找(王道408)
数据结构·学习·程序人生·考研·算法
王哈哈^_^17 小时前
【完整源码+数据集】蓝莓数据集,yolo11蓝莓成熟度检测数据集 3023 张,蓝莓成熟度数据集,目标检测蓝莓识别算法系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·ai·视觉检测
王哈哈^_^17 小时前
【完整源码+数据集】高空作业数据集,yolo高空作业检测数据集 2076 张,人员高空作业数据集,目标检测高空作业识别系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·目标跟踪·视觉检测
一条数据库17 小时前
猫狗识别数据集:34,441张高质量标注图像,深度学习二分类任务训练数据集,计算机视觉算法研发,CNN模型训练,图像识别分类,机器学习实践项目完整数据资
深度学习·算法·机器学习
bloxd yzh17 小时前
图论基础概念
算法
小白程序员成长日记17 小时前
2025.11.09 力扣每日一题
算法·leetcode·职场和发展
hansang_IR18 小时前
【题解】洛谷 P1477 [NOI2008] 假面舞会 [思维 + 图论]
c++·算法·图论·思维
天选之女wow18 小时前
【代码随想录算法训练营——Day59】图论——47.参加科学大会、94.城市间货物运输I
算法·图论