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;
}
};
相关推荐
17´14 分钟前
从0到机器视觉工程师(五):C++设计模式
开发语言·c++·设计模式
小鹏编程19 分钟前
C++和Python中负数取余结果的区别
c++·python
鲁班相信爱情30 分钟前
Qt: 无法运行rc.exe
c++·qt
重生之我是数学王子35 分钟前
使用Qt实现json数据的格式检测并序列化输出 Qt5.4.0环境
c++·qt·json
Ritsu栗子38 分钟前
代码随想录算法训练营day23
c++·算法
~糖炒栗子~39 分钟前
[Day 12]904.水果成篮
数据结构·c++·算法·leetcode
Adunn40 分钟前
算法基础 - 二分查找
数据结构·c++·算法
HUT_Tyne26541 分钟前
力扣--283.移动零
数据结构·算法·leetcode
ALISHENGYA42 分钟前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之循环结构(while循环应用)
开发语言·数据结构·c++·算法
久睡成瘾.44643 分钟前
《代码随想录》Day29打卡!
数据结构·算法