2023-05-21 LeetCode每日一题(蓄水)

这篇具有很好参考价值的文章主要介绍了2023-05-21 LeetCode每日一题(蓄水)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

2023-05-21每日一题

一、题目编号

LCP 33. 蓄水

二、题目链接

点击跳转到题目位置

三、题目描述

给定 N 个无限容量且初始均空的水缸,每个水缸配有一个水桶用来打水,第 i 个水缸配备的水桶容量记作 bucket[i]。小扣有以下两种操作:

升级水桶:选择任意一个水桶,使其容量增加为 bucket[i]+1
蓄水:将全部水桶接满水,倒入各自对应的水缸
每个水缸对应最低蓄水量记作 vat[i],返回小扣至少需要多少次操作可以完成所有水缸蓄水要求。

注意:实际蓄水量 达到或超过 最低蓄水量,即完成蓄水要求。

四、解题代码

class Solution {
public:
    int storeWater(vector<int>& bucket, vector<int>& vat) {
        int n = bucket.size();
        int max_cnt = 0;
        for(int i = 0; i < n; ++i){
            if(bucket[i] == 0){
                max_cnt = max(max_cnt, vat[i]);
                continue;
            }
            if(vat[i] % bucket[i] == 0){
                max_cnt = max(max_cnt, vat[i] / bucket[i]); 
            } else{
                max_cnt = max(max_cnt, vat[i] / bucket[i] + 1);
            }
        }
        int res = INT_MAX;
        int i = 1;//灌水次数
        while(i <= max_cnt && i < res){
            int tmp = 0;
            for(int j = 0; j < n; ++j){
                if(bucket[j] * i < vat[j]){
                    if((vat[j] - bucket[j] * i) % i == 0){
                        tmp += (vat[j] - bucket[j] * i) / i;
                    } else{
                        tmp += (vat[j] - bucket[j] * i) / i + 1;
                    }
                }
            }
            res = min(res, tmp + i);
            ++i;
        }
        if(res == INT_MAX){
            return 0;
        }
    return res;
    }
};

五、解题思路

(1) 首先先计算出最多需要灌水多少次。如果本来木桶容量为0,则最多需要灌水的是对应的水缸对应最低蓄水量。如果木桶容量不为0,则需要vat[i] / bucket[i]的上界。

(2) 接着设置最小操作次数结果为res,res设置为最大值。用i 表示灌水次数,则i必须要小于res,必须要小于等于最大灌水次数。

(3) 每次计算出对应灌水次数的操作次数。如果该灌水次数能灌满,则该次操作需要就为灌水次数,则不要额外操作。否则的话则补足额外需要的操作次数即可。最后计算出总的操作次数,更新最小结果。

(4) 最后注意,如果val都为0的话,此时结果为最大整数,此时需要返回的是0。文章来源地址https://www.toymoban.com/news/detail-453564.html

到了这里,关于2023-05-21 LeetCode每日一题(蓄水)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 2023-05-15LeetCode每日一题(按列翻转得到最大值等行数)

    点击跳转到题目位置 给定 m x n 矩阵 matrix 。 你可以从中选出任意数量的列并翻转其上的 每个 单元格。(即翻转后,单元格的值从 0 变成 1,或者从 1 变为 0 。) 返回 经过一些翻转后,行与行之间所有值都相等的最大行数 (1) 首先思考一个问题,如果光给 一行元素 的话,那

    2024年02月05日
    浏览(37)
  • (字符串 ) 剑指 Offer 05. 替换空格 ——【Leetcode每日一题】

    难度:简单 请实现一个函数,把字符串 s 中的每个 空格 替换成 “ %20 ”。 示例 1: 输入:s = “We are happy.” 输出:“We%20are%20happy.” 限制 : 0 = s 的长度 = 10000 💡思路:双指针法 如果想把这道题目做到 极致 ,就不要只用额外的辅助空间了! 首先扩充数组到每个空格替换

    2024年02月08日
    浏览(60)
  • (排序) 剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 ——【Leetcode每日一题】

    难度:简单 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数在数组的前半部分,所有偶数在数组的后半部分。 示例: 输入:nums = [1,2,3,4] 输出:[1,3,2,4] 注:[3,1,2,4] 也是正确的答案之一。 提示 : 0 = n u m s . l e n g t h = 50000 0 = nums.length = 50000 0 =

    2024年02月12日
    浏览(45)
  • LeetCode 每日一题 2023/7/10-2023/7/16

    记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 7/10 16. 最接近的三数之和 排序 先确定一个最小数 双指针确定之后两个数 7/11 1911. 最大子序列交替和 dp dp[i][0/1] 表示第i个数坐标为偶数或奇数的最大交替和 dp[i][0]=max(dp[i-1][0],dp[i-1][1

    2024年02月16日
    浏览(49)
  • LeetCode 每日一题 2023/9/25-2023/10/1

    记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 9/25 460. LFU 缓存 freqMap 以频率为索引 存放一个双向链表 每个节点存放key,value,freq keyMap 以key为索引存放在freqMap中的位置 9/26 2582. 递枕头 n个人 经过2n-2次回到开始的人 9/27 1333. 餐厅过滤

    2024年02月07日
    浏览(30)
  • LeetCode 每日一题 2023/8/7-2023/8/13

    记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 8/7 344. 反转字符串 双指针 8/8 1749. 任意子数组和的绝对值的最大值 记录最小值 最大值 8/9 1281. 整数的各位积和之差 按要求计算 8/10 1289. 下降路径最小和 II 从上到下遍历每一行 在每一

    2024年02月13日
    浏览(49)
  • LeetCode 每日一题 2023/7/24-2023/7/30

    记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 7/24 771. 宝石与石头 将宝石类型放入set中 一次判断石头中宝石个数 7/25 2208. 将数组和减半的最少操作次数 大顶堆记录当前最大值 每次取最大值减半 7/26 2569. 更新数组后处理求和查询

    2024年02月15日
    浏览(47)
  • LeetCode 每日一题 2023/8/14-2023/8/20

    记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 8/14 617. 合并二叉树 dfs深搜 8/15 833. 字符串中的查找与替换 op存放该位置能替换的数值 从头遍历每个位置 8/16 2682. 找出转圈游戏输家 模拟 8/17 1444. 切披萨的方案数 动态规划 dp[k][i][j] 表

    2024年02月12日
    浏览(46)
  • 2023-08-28 LeetCode每日一题(插入区间)

    点击跳转到题目位置 给你一个 无重叠的 ,按照区间起始端点排序的区间列表。 在列表中插入一个新的区间,你需要确保列表中的区间仍然有序且不重叠(如果有必要的话,可以合并区间)。 示例 1: 示例 2: 示例 3: 示例 4: 示例 5: 提示: 0 = intervals.length = 10 4 interval

    2024年02月11日
    浏览(46)
  • 2023-08-27 LeetCode每日一题(合并区间)

    点击跳转到题目位置 以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。 示例 1: 示例 2: 提示: 1 = intervals.length = 10 4 intervals[i].length == 2 0 = s

    2024年02月10日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包