C++单调向量算法:132模式枚举1简洁版
本题不同解法
| 包括题目及代码 | C++二分查找算法:132 模式解法一枚举3 |
| C++二分查找算法:132 模式解法二枚举2 | |
| 代码简洁 | C++二分查找算法:132 模式解法三枚举1 |
| 性能最佳 | C++单调向量算法:132 模式解法三枚举1 |
| 代码更简洁 | C++二分查找算法:132模式枚举3简洁版 |
| 代码简洁,性能优越 | C++单调向量:132模式枚举1简洁版 |
分析
时间复杂度
枚举1一轮,总时间复杂度O(n)。
步骤
for循环分三步:
一,if语句,判断是否存在比iValue大的2。
二,while循环,更新iMax2。
三,if语句,当前值加到vRight中。
变量解释
| iMax2 | 所有的合法2的最大值 |
| vRight | 记录nums[i+1,m_c)中,除了已经作为合法2外的值。已经做为合法的2,那从vRight中删除不影响结果。删除后,都是大于等于iValue值,故vRight是降序。 |
代码
核心代码
class Solution {
public:bool find132pattern(vector<int>& nums) {m_c = nums.size();const int iNotMayMinValue = -1000 * 1000 * 1000 - 1;int iMax2 = iNotMayMinValue;vector<int> vRight;for (int i = m_c - 1; i >= 0; i--){const int& iValue = nums[i];if (iValue < iMax2){m_iIndex1 = i;return true;}while (vRight.size() && (vRight.back() < iValue)){iMax2 = max(iMax2, vRight.back());vRight.pop_back();}if (vRight.empty() || (vRight.back() != iValue)){vRight.emplace_back(iValue);}}return false;}std::unordered_map<int, int> m3To2;int m_iIndex1 = -1;int m_c;
};
测试用例
template
void Assert(const T& t1, const T& t2)
{
assert(t1 == t2);
}
template
void Assert(const vector& v1, const vector& v2)
{
if (v1.size() != v2.size())
{
assert(false);
return;
}
for (int i = 0; i < v1.size(); i++)
{
Assert(v1[i], v2[i]);
}
}
int main()
{
vector nums;
bool res;
{
Solution slu;
nums = { 3,5,0,3,4 };
res = slu.find132pattern(nums);
//Assert(vector{5, 0, 5, 2, 0}, slu.m_v3To1);
Assert(0, slu.m_iIndex1);
Assert(true, res);
}
{
nums = { 1 ,2, 3,4 };
res = Solution().find132pattern(nums);
Assert(false, res);
}
{
Solution slu;
nums = { 3,1,4,2 };
res = slu.find132pattern(nums);
//Assert(vector{4, 4, 0, 1}, slu.m_v3To1);
Assert(1, slu.m_iIndex1);
Assert(true, res);
}
{
Solution slu;
nums = { -1,3,2,0 };
res = slu.find132pattern(nums);
//Assert(vector{4, 0, 0, 0}, slu.m_v3To1);
Assert(0, slu.m_iIndex1);
Assert(true, res);
}
{
Solution slu;
nums = { 1, 0, 1, -4, -3 };
res = slu.find132pattern(nums);
//Assert(vector{4, 0, 0, 0}, slu.m_v3To1);
Assert(-1, slu.m_iIndex1);
Assert(false, res);
}
//CConsole::Out(res);
}
扩展阅读
视频课程
有效学习:明确的目标 及时的反馈 拉伸区(难度合适),可以先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771
如何你想快
速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176
相关下载
想高屋建瓴的学习算法,请下载《喜缺全书算法册》doc版
https://download.csdn.net/download/he_zhidan/88348653
| 我想对大家说的话 |
|---|
| 闻缺陷则喜是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。 |
| 子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。 |
| 如果程序是一条龙,那算法就是他的是睛 |
相关文章:
C++单调向量算法:132模式枚举1简洁版
本题不同解法 包括题目及代码C二分查找算法:132 模式解法一枚举3C二分查找算法:132 模式解法二枚举2代码简洁C二分查找算法:132 模式解法三枚举1性能最佳C单调向量算法:132 模式解法三枚举1代码更简洁C二分查找算法:1…...
【ARFoundation学习笔记】2D图像检测跟踪
写在前面的话 本系列笔记旨在记录作者在学习Unity中的AR开发过程中需要记录的问题和知识点。主要目的是为了加深记忆。其中难免出现纰漏,更多详细内容请阅读原文以及官方文档。 汪老师博客 文章目录 2D图像检测创建一个图像检测工程图像追踪的禁用和启用多图像追踪…...
计算机算法分析与设计(24)---分支限界章节复习
文章目录 一、分支界限法介绍二、旅行商问题应用三、装载问题应用3.1 问题介绍与分析3.2 例题 四、0-1背包问题应用4.1 问题介绍与分析4.2 例题 一、分支界限法介绍 二、旅行商问题应用 三、装载问题应用 3.1 问题介绍与分析 3.2 例题 四、0-1背包问题应用 4.1 问题介绍与分析…...
二十三种设计模式-解密状态模式:优雅地管理对象状态
在软件开发中,经常会遇到需要根据对象的状态来改变其行为的情况。传统的实现方式可能涉及到大量的条件语句或者使用标志位来跟踪状态,导致代码复杂、难以维护。 而状态模式(State Pattern)可以提供一种优雅且灵活的解决方案&#…...
git常常用命令
这篇文章中,一些简单的,大家都知道的git 命令我就不再赘述,我只写出来最近在项目中常用到的一些命令。这些命令可以帮助我更好的开发。 git stash 请大家设想下面的场景,你的本地有两个分支,develop,fix分支…...
C语言中的大端字节序和小端字节序是什么?如何进行字节序的转换?
C语言中的大端字节序和小端字节序以及字节序的转换 引言 在计算机科学中,字节序是指多字节数据在存储或传输过程中字节的排列顺序。在C语言中,特别是在涉及二进制数据的处理、网络通信以及硬件相关的编程中,了解大端字节序和小端字节序的概…...
Flutter dio Http请求之Cookie管理
在应用开发过程中,我们进行Http通讯时会使用Cookie进行验证,今天我们就着重讲解Flutter 网络请求插件dio的cookie使用。 首先,我们要进行插件引用 # HTTP 请求 dio: ^5.1.1 cookie_jar: ^4.0.8 dio_cookie_manager: ^3.0.0# 获取沙盒路径 p…...
计算机网络的标准化工作及相关组织
一、国际化组织 计算机网络的标准化工作由一些主要的组织来进行管理和推动。以下是几个主要的计算机网络标准化的国际组织及其相关的标准: 1. 国际标准化组织(ISO):国际标准化组织负责制定各种行业的标准,包括计算机…...
智能座舱架构与芯片- (11) 软件篇 上
一、智能汽车基础软件平台分类 汽车软件主要分为应用软件和基础软件。应用软件和业务形态高度关联,不同控制器的应用软件之间差异较大。基础软件介于应用软件和硬件之间,用于屏蔽硬件特性、支撑应用软件。可有效地实现应用软件与硬件之间解耦࿰…...
2021秋招-算法-递归
算法-递归 教程: ⭐告别递归,谈谈我的一些经验 LeetCode刷题总结-递归篇 基础框架 leetcode刷题 1.leetcode-101. 对称二叉树-简单 101. 对称二叉树 给定一个二叉树,检查它是否是镜像对称的。 例如,二叉树 [1,2,2,3,4,4,3] 是对称的。…...
【Django-02】 Model模型和模型描述对象Meta
Model和Meta 概念ModelMetaModel支持的字段类型Meta 属性例子 概念 就是对象的意思,底层一个Model对应一张表,而Meta是Model的内部类,是用来描述Model和数据库表的相关元数据信息,比如主键,排序,unique_ke…...
【华为OD题库-030】阿里巴巴找黄金宝箱(V)-java
题目 一贫如洗的樵夫阿里巴巴在去砍柴的路上,无意中发现了强盗集团的藏宝地,藏宝地有编号从0-N的箱子,每个箱子上面贴有一个数字.阿里巴巴念出一个咒语数字k(k<N),找出连续k个宝箱数字和的最大值,并输出该最大值。 输入描述 第…...
centos7卸载mongodb数据重新安装时无法安装的问题
如果卸载不干净直接用 sudo find / -name mongo 查询所有关于mongo的文件,然后一个个去删除。 当然最好的办法还是去看日志信息。 直接去查看日志信息 sudo cat /var/log/mongodb/mongod.log 根据提示信息说这个没有权限操作 直接删除即可,都是之前…...
ES6 的 class 类和Typescript 的 class 类的区别
前言 为什么要理解ES6的类和TS类的区别: 都是面向对象的开发它们看着很像但是它们不一样学习明白了,避免混用 ES6 类是 JavaScript 中基于原型的面向对象编程的语法糖,而 TypeScript 类在此基础上增加了强类型检查和其他面向对象编程的特性…...
Android 12.0 默认授予应用权限
Android 12.0 默认授予应用权限 最近接到客户需求提到每当首次点开某个应用时都会弹出申请权限的弹窗,操作起来感觉很麻烦,需要将指定的这个应用默认授予权限,具体修改参照如下: frameworks/base/services/core/java/com/androi…...
Google Earth Engine(GEE)——多源遥感变量筛选(PCA主成分分析),变量筛选/降维处理
简介 很多时候我们需要进行数据的将为和筛选,传统的方法我们可以根绝经验方法进行筛选或者按照变量重要性和相关性进行分析,当然我们可以通过计算多个变量之间的主成分分析来进行变量的筛选,本文已森林生物量分析作为自变量,其它多源遥感变量作为相关性因变量,进行分类对…...
爬虫的http和https基础
HTTP响应状态码响应状态码 下面来看下详细的状态码数值和说明: 200系列: 200 OK:这个是最常见的,也是爬虫工程师最喜欢的,代表你本次的请求顺利拿到了响应,没有任何问题 201 Created:201代表…...
读像火箭科学家一样思考笔记05_思想实验
1. 思想实验室 1.1. 思想实验至少可以追溯到古希腊时期 1.1.1. 从那时起,它们就跨越各个学科,在哲学、物理学、生物学、经济学等领域取得重大突破 1.1.2. 它们为火箭提供动力,推翻政府,发展进化生物学,解开宇宙的奥…...
mac gitee新建工程遇到的一些问题
首先,记录一下mac系统显示隐藏文件夹的快捷键:commandshift句号,可以显示工程目录下的隐藏的git文件夹 一 git报错:‘origin‘does not appear to be a git repository的解决方法 找到工程目录下的.git/config文件发现里边没有remote orig…...
某60区块链安全之Call函数簇滥用实战一学习记录
区块链安全 文章目录 区块链安全Call函数簇滥用实战一实验目的实验环境实验原理实验内容实验过程 Call函数簇滥用实战一 实验目的 学会使用python3的web3模块 学会以太坊Delegatecall漏洞分析及利用 实验环境 Ubuntu18.04操作机 实验工具 python3 实验原理 call 外部调用…...
2026年AI开发者大会推荐:3类人必须参会——算法工程师、MLOps架构师、AI产品负责人(错过将落后整整一代技术周期)
更多请点击: https://intelliparadigm.com 第一章:2026年AI开发者大会推荐 核心亮点与技术前瞻 2026年AI开发者大会(AIDC 2026)将于上海张江科学城举行,聚焦“可信赖AI的工程化落地”。本届大会首次设立「开源模型工…...
告别命令行:用VNC+树莓派打造你的轻量级家庭服务器(Raspberry Pi OS Bullseye)
告别命令行:用VNC树莓派打造你的轻量级家庭服务器(Raspberry Pi OS Bullseye) 将树莓派改造成24小时运行的家庭服务器,是许多技术爱好者的共同选择。无论是作为下载机、智能家居中枢还是媒体服务器,这个小巧的设备都能…...
高级MoveIt编程技巧:自定义运动规划器和优化算法的实现方法
高级MoveIt编程技巧:自定义运动规划器和优化算法的实现方法 【免费下载链接】moveit :robot: The MoveIt motion planning framework 项目地址: https://gitcode.com/gh_mirrors/mo/moveit MoveIt是一个强大的机器人运动规划框架,为开发者提供了灵…...
Python量化分析库EigenLedger:一站式投资组合绩效评估与优化工具
1. 项目概述:EigenLedger,一个为投资者赋能的Python量化分析库如果你是一名金融从业者、量化爱好者,或者只是一个希望对自己的投资组合有更深入理解的个人投资者,那么你很可能已经对市面上那些庞大而复杂的金融分析工具感到头疼。…...
构建本地优先的代码片段管理工具:从设计到实践
1. 项目概述:一个为开发者量身定制的代码片段管理工具如果你和我一样,是个每天和代码打交道的开发者,那你肯定遇到过这样的场景:为了解决一个特定的问题,你花了半天时间在网上搜索、调试,终于写出了一段堪称…...
99AI全栈框架解析:从开源模型到可交付AI应用的工程实践
1. 项目概述:当开源模型遇上“99AI”,一个全栈AI应用的新范式最近在GitHub上看到一个挺有意思的项目,叫“vastxie/99AI”。光看名字,你可能会觉得这又是一个蹭AI热点的玩具项目,或者是一个简单的模型调用封装。但当我点…...
高速电流监测器响应速度优化与运放设计实践
1. 电流监测器响应速度的关键影响因素在高速光电检测系统中,电流监测器的响应速度直接决定了整个系统的实时性能。MAX4007作为一款高精度高压侧电流监测器,其标准配置下的响应时间往往成为系统瓶颈。通过深入分析,我们发现影响响应速度的核心…...
李飞飞做AI游戏,拿了4个亿
Jay 发自 凹非寺量子位 | 公众号 QbitAI 李飞飞又拿到钱了。5600万美元。 不是做世界模型的World Labs,是她联创的一家AI游戏公司,叫Astrocade。 你可能没听过这个名字。 我第一反应也是,等等,飞飞老师什么时候还搞了个游戏公司&a…...
Flair:为AI智能体构建本地化身份、记忆与灵魂系统
1. 项目概述:为AI智能体注入“灵魂”与“记忆”在AI智能体(Agent)的开发浪潮中,我们常常面临一个核心痛点:智能体本质上是“健忘的”。每次对话或任务执行结束后,它便回归到一张白纸的状态,之前…...
避坑指南!IDEA + WSL 2 + Java 8 环境配置的四大终极深坑
## 避坑指南!IDEA WSL 2 Java 8 环境配置的四大终极深坑这确实是一个非常值得总结的“血泪史”。在 WSL 2 环境下折腾 IntelliJ IDEA 和 Java 8,很多坑都是由于 JetBrains 尝试重构远程开发架构导致的。 为了方便你发文章,我把这几天的“排…...
