递增的三元子序列

题目链接

递增的三元子序列

题目描述

注意点

  • 1 <= nums.length <= 500000
  • 子序列的三个元素在原数组中可以不是连续的
  • 实现时间复杂度为 O(n) ,空间复杂度为 O(1) 的解决方案

解答思路

  • 使用贪心算法,在遍历数组时,要记录当前数组中的最小值minVal (方便找第二小的值)以及递增二元组中的较大值tupleMaxVal (方便找递增三元子序列)。如果当前值大于tupleMaxVal,说明找到了递增三元子序列;如果当前值大于minVal 小于tupleMaxVal,说明找到了更小的递增二元组,需要更新tupleMaxVal ;如果小于minVal,则需要更新minVal,后续更新tupleMaxVal时只需要与minVal进行比较即可

代码

class Solution {public boolean increasingTriplet(int[] nums) {// 当前数组内的最小值int minVal = Integer.MAX_VALUE;// 递增二元组的较大值int tupleMaxVal = Integer.MAX_VALUE;for (int num : nums) {// 找到递增三元组if (num > tupleMaxVal) {return true;}// 找到更小的递增二元组if (num > minVal && num < tupleMaxVal) {tupleMaxVal = num;}// 找到子数组最小值if (num < minVal) {minVal = num;}}return false;}
}

关键点

  • 贪心算法的思想
  • 更新当前数组的最小值和递增二元组的较大值

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

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

相关文章

大模型学习与实践笔记(五)

一、环境配置 1. huggingface 镜像下载 sentence-transformers 开源词向量模型 import os# 设置环境变量 os.environ[HF_ENDPOINT] https://hf-mirror.com# 下载模型 os.system(huggingface-cli download --resume-download sentence-transformers/paraphrase-multilingual-…

回声状态网络(Echo State Networks,ESN)详细原理讲解及Python代码实现

回声状态网络&#xff08;Echo State Networks,ESN&#xff09;详细讲解及Python代码实现 1 基本概念 回声状态网络是一种循环神经网络。ESN 训练方式与传统 RNN 不同。网络结构如下图&#xff1a; &#xff08;1&#xff09;储层&#xff08;Reservoir&#xff09;&#x…

DCP文件传输的重要性与应用

在数字时代&#xff0c;文件传输已成为商业运作中不可或缺的一环。随着企业越来越多地采用云基础设施和服务&#xff0c;有效地在云和团队之间传输大文件和数据集变得至关重要。在这一背景下&#xff0c;数据复制协议&#xff08;DCP&#xff09;文件传输应运而生&#xff0c;引…

推特Ads投放

一、准备工作&#xff1a; 推特广告账户&#xff1a; 您需要在推特上拥有一个有效的广告账户。 支付方式&#xff1a; 您需要关联一个有效的支付方式&#xff0c;通常是信用卡或其他支持的支付方式。 广告内容符合政策&#xff1a; 您的广告内容必须符合推特的广告政策&#…

Spring Boot - Application Events 的发布顺序_ApplicationStartingEvent

文章目录 概述Code源码分析 概述 Spring Boot 的广播机制是基于观察者模式实现的&#xff0c;它允许在 Spring 应用程序中发布和监听事件。这种机制的主要目的是为了实现解耦&#xff0c;使得应用程序中的不同组件可以独立地改变和复用逻辑&#xff0c;而无需直接进行通信。 …

Java SE入门及基础(8)

关系运算符和逻辑运算符 1. 关系运算符 关系运算符包含 > < > < ! boolean result 2 > 3 ; boolean result1 10 10 ; 关系运算符比较的结果是一个布尔值 2. 逻辑运算符 逻辑运算符包含&#xff1a; 逻辑与 &&&#xff…

中间人攻击如何进行防护

中间人攻击&#xff08;Man-in-the-Middle Attack&#xff0c;简称 MITM 攻击&#xff09;是一种常见的网络攻击方式&#xff0c;攻击者通过截获两个通信实体之间的通信数据&#xff0c;并在此基础上进行篡改、窃取或伪造等恶意行为。这种攻击方式因其攻击手段的隐蔽性和难以防…

城市排水管网监测系统主要功能与特点

城市排水管网监测系统解决方案&#xff0c;通过在管网上安装数据监测设备&#xff0c;工作人员在调度中心即可远程监测整个管网的压力、流量、水质等参数&#xff0c;实现泵站远程监控及阀门远程控制&#xff0c;保障管网压力平衡和流量稳定&#xff0c;及时发现和预测爆管事故…

java SSM物资采购管理系统myeclipse开发mysql数据库springMVC模式java编程计算机网页设计

一、源码特点 java SSM物资采购管理系统是一套完善的web设计系统&#xff08;系统采用SSM框架进行设计开发&#xff0c;springspringMVCmybatis&#xff09;&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代 码和数据库&#xff0c;系统主要采…

鸿蒙原生应用再添新丁!天眼查 入局鸿蒙

鸿蒙原生应用再添新丁&#xff01;天眼查 入局鸿蒙 来自 HarmonyOS 微博1月12日消息&#xff0c;#天眼查启动鸿蒙原生应用开发#作为累计用户数超6亿的头部商业信息查询平台&#xff0c;天眼查可以为商家企业&#xff0c;职场人士以及普通消费者等用户便捷和安全地提供查询海量…

各版本 操作系统 对 .NET Framework 与 .NET Core 支持

有两种类型的受支持版本&#xff1a;长期支持 (LTS) 版本和标准期限支持 (STS) 版本。 所有版本的质量都是一样的。 唯一的区别是支持的时间长短。 LTS 版本可获得为期三年的免费支持和补丁。 STS 版本可获得 18 个月的免费支持和修补程序。 有关详细信息&#xff0c;请参阅 .N…

学完C/C++,再学Python是一种什么体验?

你好&#xff0c;我是安然无虞。 文章目录 变量及类型变量类型动态类型特性 注释输入输出通过控制台输出通过控制台输入 运算符算术运算符关系运算符逻辑运算符赋值运算符 条件循环语句条件语句语法格式代码案例缩进和代码块空语句pass 循环语句while循环语法格式代码案例 for…