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

刷代随有感(134):单调栈——下一个更大元素I(难点涉及哈希表与单调栈的结合)

单调栈处理的是下标!

题干:

代码:

class Solution {
public:vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {stack<int>ddst;unordered_map<int,int>umap;vector<int>res(nums1.size(), -1);if(nums1.size() == 0)return res;for(int i = 0; i < nums1.size(); i++){umap[nums1[i]] = i;}ddst.push(0);for(int i = 1; i < nums2.size(); i++){if(nums2[i] <= nums2[ddst.top()]) ddst.push(i);else{while(!ddst.empty() && nums2[i] > nums2[ddst.top()]){//结果记录if(umap.count(nums2[ddst.top()]) > 0){int index = umap[nums2[ddst.top()]];//获取此数组2元素(栈顶)在数组1中下标值res[index] = nums2[i];//将遍历到的(不是栈顶)放入res中}ddst.pop();//记录完成后弹出(持续)}ddst.push(i);}}return res;}
};

哈希表的思想:在数组2里找元素而在数组1里面确定,涉及映射关系考虑哈希map。

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

相关文章:

  • Linux云计算 |【第五阶段】CLOUD-DAY5
  • 被上传文件于后端的命名策略
  • 哈希表 算法专题
  • unity3d————[HideInInspector]
  • Soanrquber集成Gitlab 之 导入Gitlab项目
  • 论区块链技术及应用
  • GPT避坑指南:如何辨别逆向、AZ、OpenAI官转
  • Qt 文本文件读写与保存
  • Linux基础环境搭建(CentOS7)- 安装Scala和Spark
  • SpringBoot 下的Excel文件损坏与内容乱码问题
  • 官宣下代GPU存在缺陷,50系显卡或将迎来涨价
  • 使用pytorch实现LSTM预测交通流
  • C/C++(八)C++11
  • 使用three.js 实现 自定义绘制平面的效果
  • 玩转Docker | 使用Docker部署捕鱼网页小游戏
  • 第2章 Android App开发基础
  • 通过 SYSENTER/SYSEXIT指令来学习系统调用
  • Nginx开发实战——网络通信(一)
  • w外链如何跳转微信小程序
  • 获取平台Redis各项性能指标
  • STM32 HAL 点灯
  • 【http作业】
  • WPF+MVVM案例实战(十一)- 环形进度条实现
  • 简述MCU微控制器
  • 微服务的雪崩问题
  • Java基础(4)——构建字符串(干货)
  • logback日志脱敏后异步写入文件
  • 电容的基本知识
  • 【Axure高保真原型】分级树筛选中继器表格
  • STM32 I2C通信:硬件I2C与软件模拟I2C的区别