单调栈第二天(还没写完)

503.下一个更大元素II

力扣题目链接(opens new window)

给定一个循环数组(最后一个元素的下一个元素是数组的第一个元素),输出每个元素的下一个更大元素。数字 x 的下一个更大的元素是按数组遍历顺序,这个数字之后的第一个比它更大的数,这意味着你应该循环地搜索它的下一个更大的数。如果不存在,则输出 -1。

示例 1:

  • 输入: [1,2,1]
  • 输出: [2,-1,2]
  • 解释: 第一个 1 的下一个更大的数是 2;数字 2 找不到下一个更大的数;第二个 1 的下一个最大的数需要循环搜索,结果也是 2。

看到题目的第一想法

        利用昨天的单调栈的思路来写

        但是它是循环数组该怎么解决?

        遍历完一次后再遍历一次,将栈中剩余的弹出

        最后剩余的赋值为-1

        成功做出来

看到代码随想录的想法

        没有我这么麻烦,for循环范围放大为2*length,nums[i%length]取模,逻辑和之前相同

        若当前比栈里的小则直接存入

        若当前比栈里的大,则弹出,栈顶下标对应的第一个最大值为栈里的值

自己实现时出现的困难

        把result全部赋值为-1 自己就不用处理-1了

 

class Solution {public int[] nextGreaterElements(int[] nums) {//也是用单调栈来写?//for循环两次到末尾Stack<Integer> stack = new Stack<>();//需要遍历到当前下标的前一个位置?stack.push(0);int[] result = new int[nums.length];for(int i=1;i<nums.length;i++){if(nums[stack.peek()]>=nums[i]){stack.push(i);}else{while(!stack.isEmpty()&&nums[stack.peek()]<nums[i]){result[stack.peek()] = nums[i];stack.pop();}//不要忘了把这个值也push进去stack.push(i);}}//此时stack中残留的元素://1 nums[i]末尾的元素//2 比较大的几个元素if(!stack.isEmpty()){for(int i=0;i<nums.length;i++){            while(!stack.isEmpty()&&nums[stack.peek()]<nums[i]){//弹出来的下标对应result 的下标result[stack.peek()] = nums[i];stack.pop();}}}while(!stack.isEmpty()){result[stack.peek()] = -1;stack.pop();}return result;}
}

42. 接雨水

力扣题目链接(opens new window)

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

示例 1:

  • 输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]
  • 输出:6
  • 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。

看到题目的第一想法

        用单调栈,没想清楚处理逻辑,要怎么计算雨水

看到代码随想录的第一想法

       用单调栈,

       遇到第一个比栈顶大的元素时,弹出栈顶做记录,再利用当前遍历到的值计算差值和下标差值

自己实现时遇到的困难

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

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

相关文章

一、对人工智能大模型了解与认知

黑8说 月黑风高&#xff0c;乌云密布&#xff0c;树木低垂&#xff0c;黯淡沉闷。这黎明前的风暴&#xff0c;预示着新时代的变革即将到来。 在一个8线小城市的办公室中 黑8对主任说&#xff1a; 世界上有男人、女人、人妖&#xff0c;米国有1/3男&#xff0c;2/3女…&#xff…

Scratch:启蒙少儿编程的图形化魔法

在当今这个数字化时代&#xff0c;编程已经成为了一项重要的基础技能。就像学习阅读和写作一样&#xff0c;掌握编程能够打开通往未来世界的大门。对于孩子们来说&#xff0c;Scratch作为一种图形化编程语言&#xff0c;不仅简单有趣&#xff0c;而且非常适合作为编程学习的入门…

VS生成报错:MSB8036 The Windows SDK version 8.1 was not found.找不到 Windows SDK 版本 8.1

目录 一、查看本机SDK二、 解决法一&#xff1a;适配本电脑的SDK法二&#xff1a;下载SDK 8.1 VS生成报错&#xff1a;MSB8036 找不到 Windows SDK 版本 8.1。请安装所需版本的 Windows SDK&#xff0c;或者在项目属性页中或通过右键单击解决方案并选择“重定解决方案目标”来更…

解决 [Vue warn]:Avoid mutating a prop directly 警告

错误信息 [Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop’s value. Prop being mutated: “xxx” 错误原因 所有的 prop 都使得…

感谢有你,1Panel开源面板项目致敬社区开发者

2024年1月24日&#xff0c;1Panel开源面板项目GitHub Star数成功突破15,000大关。 1Panel开源项目&#xff08;https://github.com/1Panel-dev&#xff09;于2023年3月20日正式发布。作为一款现代化、开源的Linux服务器运维管理面板&#xff0c;1Panel旨在通过开源的方式&…

臻于至善,CodeArts Snap 二维绘图来一套不?

前言 我在体验 华为云的 CodeArts Snap 时&#xff0c;第一个例子就是绘制三角函数图像&#xff0c;功能注释写的也很简单。 业务场景中&#xff0c;有一类就是需要产出各种二维图形的&#xff0c;比如&#xff0c;折线图、散点图、柱状图等。 为了提前积累业务素材&#xf…

iOS推送通知

文章目录 一、推送通知的介绍1. 简介2. 通知的分类 二、本地通知1. 本地通知的介绍2. 实现本地通知3. 监听本地通知的点击 三、远程通知1. 什么是远程通知2. 为什么需要远程通知3. 远程通知的原理4. 如何做远程通知5. 远程通知证书配置6. 获取远程推送要用的 DeviceToken7. 测试…

【JavaEE进阶】 数据库连接池与MySQL企业开发规范

文章目录 🌴数据库连接池🎋数据库连接池的使用🎄MySQL企业开发规范⭕总结🌴数据库连接池 数据库连接池负责分配、管理和释放数据库连接,它允许应⽤程序重复使⽤⼀个现有的数据库连接,⽽不是再重新建⽴⼀个. 没有使⽤数据库连接池的情况:每次执⾏SQL语句,要先创建⼀…

OpenHarmony—类型转换仅支持as T语法

规则&#xff1a;arkts-as-casts 级别&#xff1a;错误 在ArkTS中&#xff0c;as关键字是类型转换的唯一语法&#xff0c;错误的类型转换会导致编译时错误或者运行时抛出ClassCastException异常。ArkTS不支持使用语法进行类型转换。 当需要将primitive类型&#xff08;如num…

DS:单链表的实现(超详细!!)

创作不易&#xff0c;友友们点个三连吧&#xff01; 在博主的上一篇文章中&#xff0c;很详细地介绍了顺序表实现的过程以及如何去书写代码&#xff0c;如果没看过的友友们建议先去看看哦&#xff01; DS&#xff1a;顺序表的实现&#xff08;超详细&#xff01;&#xff01;&…

交叉导轨为何要保持日常清洁?

在工业自动化的发展中&#xff0c;交叉导轨因其具有精度高、高刚性、高耐磨性等特点&#xff0c;在数控技术的发展中得到了越来越多的使用&#xff0c;对于交叉导轨来说&#xff0c;保持日常清洁对其性能和寿命具有重要意义。 1、防止灰尘和杂质的侵入&#xff1a;交叉导轨在机…

U-Boot 命令解析(二)

U-Boot 命令解析&#xff08;二&#xff09; 网络操作命令ping 命令dhcp 命令nfs 命令tftp 命令 MMC 命令查看 MMC 设备切换 MMC 设备MMC 读命令MMC 写命令MMC 擦除命令 更多内容 接 U-Boot 常用命令&#xff08;一&#xff09;&#xff0c;我们继续介绍 U-Boot 的常用命令。 …