贪心算法篇2

“星辰野草,造出无边的天地~” 


最⻓递增⼦序列

(1) 题目解析    

(2) 算法原理        

class Solution {
public:int lengthOfLIS(vector<int>& nums) {// 使用dp int n = nums.size(), ret = 1;// 初始化为1vector<int> dp(n+1,1);// 从第二个位置开始for(int i=1;i<n;++i){// 子序列搜索for(int j=0;j<i;++j){// 可以进行拼接if(nums[j] < nums[i]) dp[i] = max(dp[i],dp[j] + 1);}ret = max(ret,dp[i]);}return ret;}
};class Solution {
public:int lengthOfLIS(vector<int>& nums) {// 使用贪心vector<int> vec; // 记录子序列长度vec.push_back(nums[0]); // 初始化for(int i=1;i<nums.size();++i){// 如果是最大的直接插入即可if(vec.back() < nums[i]) vec.push_back(nums[i]);else{// 二分查找int left = 0,right = vec.size() - 1;while(left < right){int mid = (left + right) >> 1;// 哪个分支暗含“相等” 不能跳过midif(nums[i] > vec[mid]) left = mid+1;else right=mid;}// 更新较小值vec[left] = nums[i];}}return vec.size();}
};

递增的三元⼦序列

(1) 题目解析

        这题同上一道题相差无几!甚至更为简单,因为我们只需要判断这个子序列长度是否超过3。

(2) 算法原理   

class Solution {
public:bool increasingTriplet(vector<int>& nums) {// 这里默认给b一个无穷大的值// 由nums中的小数来替换int a = nums[0],b = INT_MAX;for(int i=1;i<nums.size();++i){if(b < nums[i]) return true; // 找打了else if(a < nums[i]) b = nums[i]; // 替换belse a = nums[i];}return false;}
};

最⻓连续递增序列 

(1) 题目解析

(2) 算法原理 

class Solution {
public:int findLengthOfLCIS(vector<int>& nums) {int n = nums.size();int left = 0,right = 1,ret = 0;while(left < n){while(right < n && nums[right] > nums[right-1]) right++;ret = max(ret,right - left);left = right++;}return ret;}
};

买卖股票的最佳时机

(1) 题目解析  

(2) 算法原理

class Solution {
public:int maxProfit(vector<int>& prices) {int prevMin = prices[0], n = prices.size();int ret = 0;for(int i=1;i<n;++i){ret = max(ret,prices[i] - prevMin);prevMin = min(prevMin,prices[i]);   // 更新}return ret;}
};

买卖股票的最佳时机 Ⅱ 

(1) 题目解析 

(2) 算法原理 

class Solution {
public:int maxProfit(vector<int>& prices) {// 方法1:双指针+贪心int n = prices.size();int left = 0,right = left + 1;int ret = 0;while(left < n){while(right < n && prices[right] > prices[right - 1]) right++;ret += prices[right - 1] - prices[left];left = right++;}return ret;}
};class Solution {
public:int maxProfit(vector<int>& prices) {// 方法2:拆分交易int ret = 0;for(int i=0;i<prices.size()-1;++i){if(prices[i] < prices[i+1]) ret += prices[i+1] - prices[i];}return ret;}
};

 


本篇到此结束,感谢你的阅读。

祝你好运,向阳而生~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/452551.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习复习(5)——激活函数

目录 激活函数分类 区别与优缺点 饱和激活函数 非饱和激活函数 综合考虑 Sigmoid激活函数 Tanh激活函数 ReLU激活函数 Leaky Relu激活函数 Swish激活函数 激活函数分类 激活函数可以分为两大类 &#xff1a; 饱和激活函数&#xff1a;sigmoid、tanh非饱和激活函数:…

《区块链简易速速上手小册》第2章:区块链的工作原理(2024 最新版)

文章目录 2.1 分布式账本技术&#xff08;DLT&#xff09;2.1.1 DLT基础知识2.1.2 主要案例&#xff1a;供应链管理2.1.3 拓展案例 1&#xff1a;数字身份2.1.4 拓展案例 2&#xff1a;投票系统 2.2 加密和安全性2.2.1 加密技术基础2.2.2 主要案例&#xff1a;比特币交易2.2.3 …

基于springboot原创歌曲分享平台源码和论文

随着信息技术和网络技术的飞速发展&#xff0c;人类已进入全新信息化时代&#xff0c;传统管理技术已无法高效&#xff0c;便捷地管理信息。为了迎合时代需求&#xff0c;优化管理效率&#xff0c;各种各样的管理平台应运而生&#xff0c;各行各业相继进入信息管理时代&#xf…

kubectl命令

kubenetes部署服务的流程 以部署一个nginx服务来说明kubernetes系统各个组件调用关系&#xff1a; 1. 首先要明确&#xff0c;一旦kubernetes环境启动之后&#xff0c;master和node都会将自身的信息存储到etcd数据库中 2. 一个nginx服务的安装请求会首先被发送到master节点的ap…

VitePress-07-文档中代码块的使用全解

说明 本文会介绍 vitepress 中markdown文档对 代码块的支持特性&#xff0c; 包括基本使用、代码高亮、展示行号、指定代码行高亮、代码聚焦、以及代码删除/新增标记、代码错误和警告标记 等特性的使用。 代码块的基本语法 代码块的基本效果就是 &#xff1a;代码高亮展示&…

C语言进阶之文件操作

一、什么是文件 磁盘上的文件是文件。 但是在程序设计中&#xff0c;我们一般谈的文件有两种&#xff1a;程序文件、数据文件&#xff08;从文件功能的角度来分类的&#xff09;。 1&#xff09;程序文件 包括源程序文件&#xff08;后缀为.c&#xff09;,目标文件&#xff…

【Springcloud篇】学习笔记七(十三章):Stream消息驱动

第十三章_Stream消息驱动 1.消息驱动Stream介绍 1.1Stream为什么被引入 常见MQ(消息中间件)&#xff1a; ActiveMQRabbitMQRocketMQKafka 有没有一种新的技术诞生&#xff0c;让我们不再关注具体MQ的细节&#xff0c;我们只需要用一种适配绑定的方式&#xff0c;自动的给我…

Codeforces Beta Round 8 C. Looking for Order 【状压DP】

C. Looking for Order 题意 平面直角坐标系上有 n n n 个物品&#xff0c;还有一个初始背包位置 ( x 0 , y 0 ) (x_0, y_0) (x0​,y0​)&#xff0c;从背包位置出发&#xff0c;每次最多携带两个物品回来背包&#xff0c;求把所有物品带回背包位置要走的最短距离&#xff0c…

[python]基于Ultra-Fast-Lane-Detection-v2车道线实时检测onnx部署

【论文地址】 https://arxiv.org/pdf/2206.07389.pdf 【框架地址】 https://github.com/cfzd/Ultra-Fast-Lane-Detection-v2 【框架介绍】 Ultra-Fast-Lane-Detection-v2&#xff08;UFL-D-v2&#xff09;算法是一种高效的车道线检测算法&#xff0c;它旨在快速准确地识别…

ElementUI Form:Form表单

ElementUI安装与使用指南 Form表单 点击下载learnelementuispringboot项目源码 效果图 el-form.vue&#xff08;Form表单&#xff09;页面效果图 项目里 el-form.vue代码 <script> export default {name: el_form,data() {var checkAge (rule, value, callback…

论文阅读-一种用于大规模分布式文件系统中基于深度强化学习的自适应元数据管理方案

名称&#xff1a; An Adaptive Metadata Management Scheme Based on Deep Reinforcement Learning for Large-Scale Distributed File Systems I. 引言 如今&#xff0c;大型集群文件系统的规模已达到PB甚至EB级别&#xff0c;由此产生的数据呈指数级增长。系统架构师不断设…

ai创作软件有哪些?这5个软件了解一下

ai创作软件有哪些&#xff1f;随着科技的飞速发展&#xff0c;人工智能&#xff08;AI&#xff09;在各个领域都展现出了惊人的实力。特别是在内容创作领域&#xff0c;AI技术已经成为了助力创作者们提高效率、释放创意的得力助手。今天&#xff0c;我们将为大家介绍五款AI创作…