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

leetcode456 132 Pattern

给定数组,找到 i < j < k i < j < k i<j<k,使得 n u m s [ i ] < n u m s [ k ] < n u m s [ j ] nums[i] < nums[k] < nums[j] nums[i]<nums[k]<nums[j]

最开始肯定想着三重循环,时间复杂度 O ( n 3 ) O(n^3) O(n3)
接着是二重循环
先找到一组 i < j i <j i<j,使得 n u m s [ i ] < n u m s [ j ] nums[i] < nums[j] nums[i]<nums[j],接着在后面找能放在中间的 k k k
其中 n u m s [ i ] nums[i] nums[i]只要存储左边最小,因为他比其他的更有潜力成为答案

class Solution {
public:bool find132pattern(vector<int>& nums) {int n = nums.size();if(n < 3)return false;bool flag = true;int min_i = nums[0];for(int j = 1; j + 1 < n; ++j){if(nums[j] < min_i){min_i = nums[j];continue;}for(int k = j + 1; k < n; ++k){if(min_i < nums[k] && nums[k] < nums[j]){return true;}}}return false;}
};

然后发现还是超时

所以要一个循环

考虑从右往左遍历
维护一个单调递减栈
当前元素大于栈顶元素时出栈,出栈的最后一个元素作为 n u m s [ k ] nums[k] nums[k]
这样的话相当于先找到了 n u m s [ k ] < n u m s [ j ] nums[k] < nums[j] nums[k]<nums[j]
之后只要找 n u m s [ i ] nums[i] nums[i]

class Solution {
public:bool find132pattern(vector<int>& nums) {if(nums.size() < 3)return false;int max_third = 0x80000000;stack<int> st;for(int i = nums.size() - 1; i >= 0; --i){if(nums[i] < max_third)return true;while(!st.empty() && nums[i] > st.top()){max_third = st.top();st.pop();}st.push(nums[i]);}return false;}
};
http://www.lryc.cn/news/179061.html

相关文章:

  • WordPress外贸建站Astra免费版教程指南(2023)
  • Vue之ElementUI实现登陆及注册
  • 网络代理的多面应用:保障隐私、增强安全和数据获取
  • 字节一面:深拷贝浅拷贝的区别?如何实现一个深拷贝?
  • 协议-TCP协议-基础概念02-TCP握手被拒绝-内核参数-指数退避原则-TCP窗口-TCP重传
  • PDF文件压缩软件 PDF Squeezer mac中文版​软件特点
  • VS+Qt+opencascade三维绘图stp/step/igs/stl格式图形读取显示
  • 如何在Ubuntu中切换root用户和普通用户
  • 从零开始之了解电机及其控制(10)空间矢量理论
  • PSINS工具箱学习(一)下载安装初始化、SINS-GPS组合导航仿真、习惯约定与常用变量符号、数据导入转换、绘图显示
  • 国庆day1---消息队列实现进程之间通信方式代码,现象
  • wdb_2018_2nd_easyfmt
  • 服务器数据恢复-zfs下raidz多块磁盘离线导致服务器崩溃的数据恢复案例
  • 云服务器 CentOS7 操作系统上安装Jpress (Tomcat 部署项目)
  • 【Linux】完美解决ubuntu18.04下vi不能使用方向键和退格键
  • Android studio “Layout Inspector“工具在Android14 userdebug设备无法正常使用
  • Kafka(一)使用Docker Compose安装单机Kafka以及Kafka UI
  • 网络知识点之-MSTP平台
  • Azure AD混合部署,通过 Intune 管理设备,实现条件访问
  • 2023/09/30
  • 顶级人工智能会议接收率及信息
  • NLP 01(介绍)
  • 网页采集工具-免费的网页采集工具
  • 【自监督Re-ID】ICCV_2023_Oral | ISR论文阅读
  • ElasticSearch 10000条查询数量限制
  • 视频增强修复工具Topaz Video AI mac中文版安装教程
  • 【面试题精讲】Java自增自减运算符
  • 282_WEB_对于注册、数据data_callback中进行处理的理解
  • 测试C#图像文本识别模块Tesseract的基本用法
  • 计组+系统02:30min导图复习 存储系统