leetcode 2279. 装满石头的背包的最大数量

题目如下

数据范围

示例

显然我们应该使用最少的石头装满最多的背包,典型的贪心思想。本题仅需将capacity与rocks的差值算出来排序就行。

通过代码

cpp 复制代码
class Solution {
public:
  int maximumBags(vector<int>& capacity, vector<int>& rocks, int additionalRocks) {
        int n = capacity.size();
        int count = 0;
        vector<int> c;
        for(int i = 0;i < n;i++) {
            c.push_back(capacity[i] - rocks[i]);
        }
        sort(c.begin(), c.end());
        for(int &t :c) {
            if(additionalRocks >= t) {
                additionalRocks -= t;
                count++;
            }else {
                break;
            }
        }
    return count;
}
};
相关推荐
曙曙学编程2 小时前
进阶数据结构——二叉堆
数据结构
吃辣椒的年糕3 小时前
C++ 课程学习笔记:从对象生命周期看资源管理之道
java·c语言·开发语言·c++
黑夜无路人3 小时前
redis底层数据结构——整数集合
数据结构·redis
补三补四4 小时前
支持向量机(一)
算法·机器学习·支持向量机
Zz_waiting.6 小时前
java数据结构_二叉树_5.4
数据结构·算法
天亮有惊喜6 小时前
基于改进型灰狼优化算法(GWO)的无人机路径规划
算法·matlab·路径规划·灰狼优化算法·gwo
钟离墨笺6 小时前
【c++】四种类型转换形式
开发语言·c++
程序员东min7 小时前
Python:凯撒密码
python·算法
汤姆和杰瑞在瑞士吃糯米粑粑7 小时前
【C++学习篇】C++11
开发语言·c++
_extraordinary_7 小时前
C++智能指针的使用
c++·智能指针