codeforces A -Cut Ribbon

思路

  • 基础 d p dp dp , d p i , j dp_{i,j} dpi,j 表示长度为 i i i , p i e c e piece piece 为 j j j 的数量。题目范围 4000 4000 4000 常规定义可能会 M E L MEL MEL ,所以第二维为不同的 p i e c e piece piece 的个数。
  • 枚举不同的 p i e c e s pieces pieces 长度。
  • 方程: d p i , j = d p i − l e n j , j + 1 / 0 dp_{i,j}=dp_{i-len_j,j}+1/0 dpi,j=dpi−lenj,j+1/0 。(是当前枚举长度则为 1 1 1 )

Think Twice, Code Once

cpp 复制代码
signed main() {

    int T = 1;
//    T = read();
    while (T--) {
        int n = read();
        vector<int> vec;
        for (int i = 1; i < 4; ++i) {
            int u = read();
            vec.push_back(u);
        }
        sort(vec.begin(), vec.end());
        vec.erase(unique(vec.begin(), vec.end()), vec.end());
        vector<vector<int>> dp(4000 + 10, vector<int>(vec.size()));
        auto get_sum = [&] (int j) {
            int res = 0;
            for (int i = 0; i < vec.size(); ++i) res += dp[j][i];
            return res;
        };
        for (int i = 0; i < vec.size(); ++i) dp[vec[i]][i] = 1;
        for (int i = 1; i <= n; ++i) {
            int sum = 0;
            for (int j = 0; j < vec.size(); ++j) {
                if (i - vec[j] >= 0) {
                    int tmp = get_sum(i - vec[j]);
                    if (sum < tmp) {
                        sum = tmp;
                        for (int k = 0; k < vec.size(); ++k) dp[i][k] = dp[i - vec[j]][k] + (k == j);
                    }
                }
            }
        }
        write(get_sum(n));
    }
    return 0;
}
//3119 3515 1021 7
相关推荐
Amor风信子5 分钟前
华为OD机试真题---跳房子II
java·数据结构·算法
戊子仲秋22 分钟前
【LeetCode】每日一题 2024_10_2 准时到达的列车最小时速(二分答案)
算法·leetcode·职场和发展
邓校长的编程课堂24 分钟前
助力信息学奥赛-VisuAlgo:提升编程与算法学习的可视化工具
学习·算法
sp_fyf_202441 分钟前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-03
人工智能·算法·机器学习·计算机视觉·语言模型·自然语言处理
Eric.Lee20211 小时前
数据集-目标检测系列- 螃蟹 检测数据集 crab >> DataBall
python·深度学习·算法·目标检测·计算机视觉·数据集·螃蟹检测
林辞忧1 小时前
算法修炼之路之滑动窗口
算法
￴ㅤ￴￴ㅤ9527超级帅2 小时前
LeetCode hot100---二叉树专题(C++语言)
c++·算法·leetcode
liuyang-neu2 小时前
力扣 简单 110.平衡二叉树
java·算法·leetcode·深度优先
penguin_bark2 小时前
LCR 068. 搜索插入位置
算法·leetcode·职场和发展
_GR2 小时前
每日OJ题_牛客_牛牛冲钻五_模拟_C++_Java
java·数据结构·c++·算法·动态规划