leetcode 2412. 完成所有交易的初始最少钱数

题目:2412. 完成所有交易的初始最少钱数 - 力扣(LeetCode)

题目要求的就是最差情况的本钱最少是多少,肯定是先亏钱再赚钱。

对于每个交易:

  • 如果是赚钱或保本,只有最大的本金对本钱有影响
  • 如果是亏钱,所有交易都影响本金
  • 如果全部交易都是亏钱的,最差情况下,最后一次交易的盈利应当最大

基于这些条件,可以简化计算方式:

复制代码
class Solution {
public:
    long long minimumMoney(vector<vector<int>>& transactions) {
        long long ret = 0;
        int lc = 0;
        for (int i = 0; i < transactions.size(); i++) {
            vector<int>& t = transactions[i];
            if (t[0] > t[1]) {
                ret += t[0] - t[1];
            }
            if (t[0] > lc && t[1] > lc) {
                lc = min(t[0], t[1]);
            }
        }
        ret += lc;
        return ret;
    }
};
相关推荐
刃神太酷啦3 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode
_深海凉_5 小时前
LeetCode热题100-分割回文串
算法·leetcode·职场和发展
流年如夢8 小时前
单链表Ⅲ(LeetCode)
数据结构·算法·leetcode·职场和发展
mask哥10 小时前
力扣算法java实现汇总整理(下)
java·算法·leetcode
样例过了就是过了11 小时前
LeetCode热题100 编辑距离
数据结构·c++·算法·leetcode·动态规划
khalil102011 小时前
代码随想录算法训练营Day-46 动态规划13 | 647. 回文子串、516.最长回文子序列、动态规划总结
数据结构·c++·算法·leetcode·动态规划·回文子串·回文子序列
he___H12 小时前
算法快与慢--哈希+双指针
算法·leetcode·哈希算法
凯瑟琳.奥古斯特13 小时前
力扣2760 C++滑动窗口解法
数据结构·c++·算法·leetcode·职场和发展
_深海凉_13 小时前
LeetCode热题100-不同路径
算法·leetcode·职场和发展
m0_6294947314 小时前
LeetCode 热题 100-----23.反转链表
数据结构·算法·leetcode·链表