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

C语言 | Leetcode C语言题解之第496题下一个更大元素I

题目:

题解:

// 声明一个单调栈
stack<int> st;

// 遍历数组nums2
for (int i = 0; i < nums2.size(); i++) {
  // 如果栈不为空,且当前栈顶元素 小于 nums2[i],则说明栈内元素遇到比它大的了,因此可以弹出并记录比它大的数字
  while (!st.empty() && st.top() < nums2[i]) {
    // 记录比栈顶元素大的值
    ans[st.top()] = nums2[i];
    // 弹出栈顶元素
    st.pop();
  }
  // 将nums2[i]入栈
  st.push(nums2[i]);
}
// 如果遍历完nums2,栈内元素还不为空,说明这些元素都没有找到比它大的数字
while(!st.empty()) {
  ans[st.top()] = -1;
  st.pop();
}

http://www.kler.cn/news/358676.html

相关文章:

  • 解决后端给前端的返回数据过大的问题(压缩)
  • 代码工具箱:18个实用的 JavaScript 函数
  • pytorch 张量的masked_fill函数介绍
  • flutter TabBar自定义指示器(带文字的指示器、上弦弧形指示器、条形背景指示器、渐变色的指示器)
  • Atlas800昇腾服务器(型号:3000)—YOLO全系列NPU推理【检测】(五)
  • Navicat连接openGauss数据库详细指南
  • Vue3在大数据场景下原生实现单元格合并,让Thead固定让Tbody滚动
  • Linux——传输层协议
  • vscode 远程linux服务器 连接git
  • 陈文自媒体:小红书,24小时爆99+的秘诀!
  • 视觉检测解决方案
  • 3D Slicer 教程三 ---- 坐标系
  • 小技巧——如何启动miivii控制器自带相机demo
  • 单细胞分析 | Cicero+Signac 寻找顺式共可及网络
  • c#webapi远程调试方法asp.netcore
  • 【思维导图】C语言
  • 【C语言】指针进阶【万字详细版】
  • 使用langchain和大模型API提取QA的实战教程
  • RHEL: rpm2cpio: signature hdr data: BAD, no. of bytes(19987) out of range
  • 【基于Spring Boot+Unipp的古诗词学习小程序【原创】