划分型dp,CF 1935C - Messenger in MAC

一、题目

1、题目描述

2、输入输出

2.1输入
2.2输出

3、原题链接

1935C - Messenger in MAC


二、解题报告

1、思路分析

比较简单的思路是反悔贪心,这里不展开说了,来说一下dp的做法

由于式子里面带绝对值,很烦,我们将pair按照b升序排序,那么原式就变为

sum(a) + max(b) - min(b)

我们定义状态f(i, j) 为 前 i 个数 选了 j 个数 且以 (a[i], b[i]) 结尾,即第 i 个 数必选的最小 sum(a) - min(b) 的花费,这样定义是因为第 i 个数必选,那么max(b) 一定是 b[i]

则 f(i + 1, j + 1) = min(f(k, j)) + a[i]

枚举 k的话就变成了O(N^3),考虑维护前缀最小值,可以优化到O(N^2)

滚动数组优化又可以优化空间到O(N)

2、复杂度

时间复杂度: O(N^2)空间复杂度:O(N)

3、代码详解

复制代码
 ​
cpp 复制代码
#include <bits/stdc++.h>
#define sc scanf
using i64 = long long;
using i128 = __int128;
using PII = std::pair<int, int>;
constexpr int inf32 = 1e9 + 7;
constexpr i64 inf64 = 1e18 + 7;
constexpr int P = 998244353;
constexpr double eps = 1e-6;

// #define DEBUG

void solve()
{
    int n, L;
    std::cin >> n >> L;
    std::vector<int> a(n), b(n);
    
    for (int i = 0; i < n; ++ i) std::cin >> a[i] >> b[i];

    std::vector<int> p(n);
    std::iota(p.begin(), p.end(), 0);
    std::sort(p.begin(), p.end(), [&b](int i, int j) {
        return b[i] < b[j];
    });
    
    int res = 0;
    std::vector<i64> f(n + 1, inf64);
    
    for (int k = 0; k < n; ++ k) {
        int i = p[k];
        for (int j = k + 1; j; -- j) {
            f[j + 1] = std::min(f[j + 1], f[j] + a[i]);
            if (f[j] + b[i] + a[i] <= L)
                res = std::max(res, j + 1);
        }
        f[1] = std::min<i64>(f[1], a[i] - b[i]);
        if (a[i] <= L) res = std::max(res, 1);
    }

    std::cout << res << '\n';
}

int main()
{
#ifdef DEBUG
    freopen("in.txt", "r", stdin);
    freopen("out.txt", "w", stdout);
#endif
    std::ios::sync_with_stdio(false), std::cin.tie(nullptr), std::cout.tie(nullptr);
    int _ = 1;
    std::cin >> _;
    while (_--)
        solve();
    return 0;
}
相关推荐
项目申报小狂人11 分钟前
算法应用上新!自适应更新策略差分进化算法求解球形多飞行器路径规划问题,附完整MATLAB代码
开发语言·算法·matlab
PAK向日葵6 小时前
【算法导论】PDD 0817笔试题题解
算法·面试
地平线开发者9 小时前
ReID/OSNet 算法模型量化转换实践
算法·自动驾驶
地平线开发者9 小时前
开发者说|EmbodiedGen:为具身智能打造可交互3D世界生成引擎
算法·自动驾驶
星星火柴93610 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
艾莉丝努力练剑11 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
C++、Java和Python的菜鸟12 小时前
第六章 统计初步
算法·机器学习·概率论
Cx330❀12 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
散11213 小时前
01数据结构-Prim算法
数据结构·算法·图论