LeetCode Hot 100:贪心算法

news/2024/11/1 11:26:12/

LeetCode_Hot_100_0">LeetCode Hot 100:贪心算法

121. 买卖股票的最佳时机

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:动态规划

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:贪心

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:贪心

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:动态规划

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. 划分字母区间

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;}
};

http://www.ppmy.cn/news/1543566.html

相关文章

AWS CDK 漏洞使黑客能够接管 AWS 账户

Aquasec 的安全研究人员最近在 AWS Cloud Development Kit &#xff08;CDK&#xff09; 中发现了一个关键漏洞&#xff0c;该漏洞可能允许攻击者获得对目标 AWS 账户的完全管理访问权限。 该问题于 2024 年 6 月报告给 AWS&#xff0c;影响使用版本 v2.148.1 或更早版本的 CD…

蓝牙BLE开发——红米手机无法搜索蓝牙设备?

解决 红米手机&#xff0c;无法搜索附近蓝牙设备 具体型号当时忘记查看了&#xff0c;如果你遇到有以下选项&#xff0c;记得打开~ 设置权限

初探Servlet

文章目录 1. Servlet概述1.1 定义1.2 作用 2. 主要知识点2.1 生命周期2.2 请求处理2.3 Servlet配置 3. 案例演示3.1 创建Web应用项目3.2 修改项目工件名3.3 重新部署Web项目3.4 创建WelcomeServlet3.5 编写doGet方法代码3.6 编写doPost方法代码3.7 访问WelcomeServlet 4. 小结 …

Spark窗口函数

1、 Spark中的窗口函数 窗口就是单纯在行后面加一个列 可以套多个窗口函数&#xff0c;但彼此之间不能相互引用&#xff0c;是独立的 窗口函数会产生shuffle over就是用来划分窗口的 (1) 分组聚合里面的函数&#xff0c;基…

大数据-199 数据挖掘 机器学习理论 - 决策树 模型 决策与条件 香农熵计算

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…

KVM 虚拟机Anolis OS 8.9 下利用宝塔面板中的 Docker 配置 Nextcloud + onlyoffice

第一部分&#xff1a;安装配置 nextcloud 准备 &#xff08;1&#xff09;启动一个 Anolis OS 8.9 虚拟机&#xff0c;见下图。该虚拟机为 anlisos8…0.2 虚拟机的 ssh、hostname 、IP地址都已配置好。 &#xff08;2&#xff09;宝塔面板也已安装好docker 一、环境 do…

Certimate - 免费开源的 SSL 证书托管、自动续签工具,开发者维护 90 天免费证书的救星

很完美的 SSL 证书托管工具&#xff0c;安全可靠&#xff0c;简单易用。 Certimate 是一个由国人开发的 SSL 证书管理工具&#xff0c;提供一个 web UI 界面让我们可以用简单直观的方式来管理 SSL 证书&#xff0c;申请证书、部署证书&#xff0c;以及证书到期续签都是自动完成…

网络爬虫的定义

网络爬虫&#xff0c;即Web Spider&#xff0c;是一个很形象的名字。 把互联网比喻成一个蜘蛛网&#xff0c;那么Spider就是在网上爬来爬去的蜘蛛。 网络蜘蛛是通过网页的链接地址来寻找网页的。 从网站某一个页面&#xff08;通常是首页&#xff09;开始&#xff0c;读取网页…