当前位置: 首页 > news >正文

力扣题解(递增的三元子序列)

334. 递增的三元子序列

给你一个整数数组 nums ,判断这个数组中是否存在长度为 3 的递增子序列。

如果存在这样的三元组下标 (i, j, k) 且满足 i < j < k ,使得 nums[i] < nums[j] < nums[k] ,返回 true ;否则,返回 false 。

思路:

假设a<b<c,a,b,c构成递增三元子序列,则目的就是定住a,b找符合的c。

固定a,b的做法是对于每个进入的元素,若比a小,则a为进入的元素,若比a大则和b比,比b小则更新b,反之则找到了递增的三元子序列。这样做可以成功找到的原因是,每次更新a和b,使得ab尽可能的小,方便找大的元素。先和a比再和b比,严格规定了a,b的大小关系。对于找到的c,存在两种情况,一种是a更新了b没有更新,则可以视为用原来的a和b加上c。若a,b都是更新后的,则是用当前的a,b加上c。

class Solution {
public:bool increasingTriplet(vector<int>& nums) {int a=nums[0],b=INT_MAX;for(auto e:nums){   if(a>=e){a=e;}else if(b>=e){b=e;}elsereturn true;}return false;}
};

http://www.lryc.cn/news/415335.html

相关文章:

  • 做不好PPT的原因
  • 嵌入式人工智能(45-基于树莓派4B的扩展板-舵机驱动板PCA9685)
  • 【数据结构与算法】建立多个栈的三种方案的优缺点分析
  • DjangoRF-14-创建request子应用
  • SOMEIP_ETS_005:检查字节序
  • 为什么要对医疗器械进行网络安全评估?
  • 沃尔玛1P账号的强悍作用重要反映在那些方面?——WAYLI威利跨境助力商家
  • 学习python你不能不知道的几个接单平台!实现如月上万不是梦
  • Golang面试题三(map)
  • [windows10]win10永久禁用系统自动更新操作方法
  • 《西行取经:大学生编程之路的禅悟与陷阱规避2》
  • JVM从入门到放弃
  • 中国地面太阳总辐射逐日资料
  • 微商来客小程序系统源码分享
  • Java面试题--JVM大厂篇之Parallel GC与其他垃圾回收器的对比与选择
  • 十分钟带你速通 Vue 组件
  • 基于RK3588+AI支持能源在线监测系统应用的AIOT产品方案
  • 山东大学考研机试题——整数序列
  • 一口酒一口水,不宜喝醉
  • AI6-PPOCRLabel带GPU训练
  • Unity四元数线性插值Lerp
  • Makefile 语法
  • 【运维项目经历|039】Ceph高性能云存储集群部署与优化
  • 算法刷题之哈希表
  • 【linux】linux中定时任务的巧妙运用,让你轻松解放双手
  • 【复旦微FM33 MCU 外设开发指南】系统篇——时钟
  • Android Graphics 显示系统 - 计算FPS的原理与探秘Present Fence
  • 图论:1857. 有向图中最大颜色值(拓扑排序+动态规划)
  • pytorch学习笔记3 tensor索引和切片
  • 学习记录——day23 多进程编程