LeetCode Hot 100:贪心算法

LeetCode Hot 100:贪心算法

121. 买卖股票的最佳时机

cpp 复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int minPrice = INT_MAX;
        int maxProfit = 0;
        for (int& price : prices) {
            minPrice = min(minPrice, price);
            maxProfit = max(maxProfit, price - minPrice);
        }

        return maxProfit;
    }
};

思路 1:动态规划

cpp 复制代码
class Solution {
public:
    bool canJump(vector<int>& nums) {
        int n = nums.size();
        // dp[n] 表示从下标范围 [0,i] 中的任意下标出发可以到达的最大下标
        vector<int> dp(n);
        // 初始化
        dp[0] = nums[0];
        // 状态转移
        for (int i = 1; i < n; i++) {
            if (dp[i - 1] < i)
                return false;
            dp[i] = max(dp[i - 1], i + nums[i]);
        }
        return dp[n - 1] >= n - 1;
    }
};

思路 2:贪心

cpp 复制代码
class Solution {
public:
    bool canJump(vector<int>& nums) {
        int n = nums.size();
        int max_far = 0; // 目前能跳到的最远位置

        for (int i = 0; i < n; i++) {
            if (i <= max_far) {
                max_far = max(max_far, i + nums[i]);
                if (max_far >= n - 1)
                    return true;
            }
        }

        return false;
    }
};

45. 跳跃游戏 II

思路 1:贪心

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int n = nums.size();
        int pos = n - 1, step = 0;

        while (pos > 0) {
            for (int i = 0; i < pos; i++)
                if (i + nums[i] >= pos) {
                    pos = i;
                    step++;
                    break;
                }
        }
        
        return step;
    }
};

思路 2:动态规划

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        int n = nums.size();
        // dp[i] 表示到达 i 的最少跳数
        vector<int> dp(n, INT_MAX);
        // 初始化
        dp[0] = 0;
        // 状态转移
        for (int i = 1, last = 0; i < n; i++) {
            while (last < n && last + nums[last] < i)
                last++;
            dp[i] = min(dp[i], dp[last] + 1);
        }

        return dp[n - 1];
    }
};

763. 划分字母区间

cpp 复制代码
class Solution {
public:
    vector<int> partitionLabels(string s) {
        int n = s.length();
        vector<int> last(26, 0);
        for (int i = 0; i < n; i++)
            last[s[i] - 'a'] = i;

        vector<int> ans;
        int start = 0, end = 0;
        for (int i = 0; i < n; i++) {
            end = max(end, last[s[i] - 'a']);
            if (i == end) {
                ans.push_back(end - start + 1);
                start = end + 1;
            }
        }

        return ans;
    }
};
相关推荐
南宫生3 分钟前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
冷眼看人间恩怨32 分钟前
【Qt笔记】QDockWidget控件详解
c++·笔记·qt·qdockwidget
红龙创客41 分钟前
某狐畅游24校招-C++开发岗笔试(单选题)
开发语言·c++
Lenyiin44 分钟前
第146场双周赛:统计符合条件长度为3的子数组数目、统计异或值为给定值的路径数目、判断网格图能否被切割成块、唯一中间众数子序列 Ⅰ
c++·算法·leetcode·周赛·lenyiin
yuanbenshidiaos2 小时前
c++---------数据类型
java·jvm·c++
十年一梦实验室3 小时前
【C++】sophus : sim_details.hpp 实现了矩阵函数 W、其导数,以及其逆 (十七)
开发语言·c++·线性代数·矩阵
taoyong0013 小时前
代码随想录算法训练营第十一天-239.滑动窗口最大值
c++·算法
这是我583 小时前
C++打小怪游戏
c++·其他·游戏·visual studio·小怪·大型·怪物
fpcc3 小时前
跟我学c++中级篇——C++中的缓存利用
c++·缓存
呆萌很3 小时前
C++ 集合 list 使用
c++