当前位置:首页 > 牛客 > 牛客25380题解析:分层容器倒酒问题的C++解题策略与代码详解

牛客25380题解析:分层容器倒酒问题的C++解题策略与代码详解

5个月前 (07-05)

牛客25380题解析:分层容器倒酒问题的C++解题策略与代码详解  动态规划 第1张

一、题目解读

牛客25380题要求处理一个分层容器倒酒模拟问题:给定N层容器的初始容量,以及M次操作(查询或倒酒),需动态更新容器状态并输出结果。题目核心在于理解倒酒时的容量限制与溢出处理逻辑,属于算法中的动态模拟类问题。

二、解题思路

本题采用“分层容量动态模拟”策略:

1. 用vector存储每层容量与当前水量,实现快速读写;

2. 通过循环处理操作:查询直接输出对应层状态,倒酒时需计算剩余容量,若溢出则逐层传递;

3. 关键优化:利用“当前水量”变量减少重复计算,避免超限判断错误。

三、解题步骤

1. 初始化:读入层数N、操作数M,构建容量数组并初始化当前水量为0;

2. 操作处理循环:

○ 若op=1,直接输出指定层当前水量;

○ 若op=2,执行倒酒操作:计算目标层剩余容量,若倒酒量≤剩余容量则直接更新,否则溢出至下一层递归处理;

3. 边界控制:通过x<n确保不越界,v递减至0时终止倒酒循环。

四、代码及注释

#include <iostream>
#include <vector>
using namespace std;

int main() {
    ios::sync_with_stdio(false);  // 关闭同步加速输入
    cin.tie(nullptr);
    
    int n, m;                  // 层数N,操作数M
    cin >> n >> m;
    vector<long long> capacity(n);   // 每层容量
    vector<long long> current(n, 0); // 当前水量初始化为0

    // 读取每层初始容量
    for (int i = 0; i < n; ++i) {
        cin >> capacity[i];
    }

    while (m--) {               // 处理M次操作
        int op;
        cin >> op;
        if (op == 1) {          // 查询操作
            int k;
            cin >> k;
            cout << current[k-1] << "\n"; // 输出k层当前水量(注意索引转换)
        } else {                // 倒酒操作
            int x;
            long long v;
            cin >> x >> v;
            x--;               // 转换为0-based索引

            // 从指定层开始倒酒
            while (v > 0 && x < n) {
                long long available = capacity[x] - current[x];
                if (v <= available) {
                    current[x] += v;
                    v = 0;       // 倒完终止
                } else {
                    current[x] = capacity[x]; // 装满
                    v -= available;          // 剩余量溢出
                    x++;                     // 处理下一层
                }
            }
        }
    }
    
    return 0;
}

五、总结

该解法通过分层状态维护与精确溢出计算,实现了高效模拟。关键在于利用局部变量优化容量判断,避免全局遍历。适用于处理具有层级依赖的动态资源分配问题,可拓展至类似“流量分配”场景。

参考:牛客28380题解

原创内容 转载请注明出处

标签: 动态规划
分享给朋友:

相关文章

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

题目重解我们面对一个经典背包问题的变体:给定n个物品,每个物品有重量w和价值v,背包容量为V。需要回答两个问题:1) 普通情况下能获得的最大价值;2) 必须恰好装满背包时的最大价值(若无法装满则输出0...

GESP2023年六级真题解析:动态规划解决小杨买饮料问题(洛谷3873)

GESP2023年六级真题解析:动态规划解决小杨买饮料问题(洛谷3873)

一、题目解读小杨买饮料是GESP 2023年六级认证考试中的一道经典动态规划题目,考察学生对背包问题的理解和应用能力。题目描述小杨需要购买n种饮料,每种饮料有特定的体积w和价格v,他要在不超过容量l的...

CSP-J 2019纪念品题解(洛谷P5662):动态规划+完全背包问题的实战应用

CSP-J 2019纪念品题解(洛谷P5662):动态规划+完全背包问题的实战应用

一、题目解读2019年CSP-J的“纪念品”问题(对应洛谷P5662)要求玩家在T天内通过买卖纪念品最大化金币收益。每天可交易N种商品,需计算最优策略下的最终金币数。题目强调动态规划思维与资源分配优化...

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

一、题目解读题目要求在一个n×m的网格中,从左上角到右下角选择一条路径,路径上的数字可重复取用,求取数之和的最大值。路径限制为仅能向右或向下移动。需注意路径的灵活性与重复取数的可能性,传统单向动态规划...

2024蓝桥杯省赛B组“传送阵”题解(C++代码+图论算法优化)

2024蓝桥杯省赛B组“传送阵”题解(C++代码+图论算法优化)

一、题目解读2024年蓝桥杯省B组“传送阵”题目要求处理一个包含n个节点的图,节点间存在单向传输关系。每个节点i可传送至a[i]指定的节点,形成可能存在的环结构。题目需求解从任意节点出发能到达的最长路...

牛客25461题解析:花园喷泉距离优化算法(动态规划+后缀数组解法)

牛客25461题解析:花园喷泉距离优化算法(动态规划+后缀数组解法)

一、题目解读牛客25461题要求计算一个花园中n朵花到两个喷泉的最小距离平方和。用户需输入喷泉坐标(x1,y1)和(x2,y2),以及n朵花的坐标(x,y),通过合理分配每朵花到两个喷泉的距离,使总距...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。