数组单调栈-901. 股票价格跨度、leetcode

2024-05-28 08:04

本文主要是介绍数组单调栈-901. 股票价格跨度、leetcode,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        单调栈作为一种数据结构在求解类递增、递减方面的题目中有较为广泛的应用,在以往的leetcode中所见到的相关单调栈的题目均为单一元素,今天刷到901题目时,想到了将数组元素作为单调栈中元素的方法进行求解。

题目链接及描述

901. 股票价格跨度 - 力扣(LeetCode)

题目分析        

        做这到题目首先想到的是使用一个数组将其元素依次存起来,随后将其转换为一个数组相关的题目,但由于数组需要实现开辟好空间,不太好确定,考虑使用List来实现,当调用next方法就将其存储到List集合中。此时List集合中的元素类型为一个一维数组,并且数组大小为2,第一个元素为price,第二个元素为price对应的价格跨度。

        将示例代码构造为阶梯图如下所示:

        最左边元素为Integer.MAX_VALUE,添加此元素,可以减少栈的非空判断。减少代码复杂度。

        根据题目:当日股票价格的 跨度 被定义为股票价格小于或等于今天价格的最大连续日数。故单调栈中存储的元素应为递减的,每当调用依次next方法,需要不断循环弹出当前栈顶小于当前价格price的元素,最后当前价格price对应的下标 - 栈顶元素对应的下标即为所求结果。当遍历到75时当前栈如下所示:

        遍历到元素75,此时栈中的情况:上图中下标2和下标4对应的蓝色柱形条表示已经出栈的元素。

        循环遍历当前栈顶元素与元素75进行比较,最终下标3对应的元素70出栈,则75对应的结果为5 - 1 = 4。

代码编写:

class StockSpanner {public Deque<int[]> mst;public int idx;public StockSpanner() {this.mst = new ArrayDeque<>();this.idx = 0;mst.addLast(new int[]{Integer.MAX_VALUE, -1});}public int next(int price) {while(!mst.isEmpty() && price >= mst.peekLast()[0]){mst.pollLast();}int ans = idx - mst.peekLast()[1];mst.addLast(new int[]{price, idx++});return ans;}
}

        

这篇关于数组单调栈-901. 股票价格跨度、leetcode的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1009995

相关文章

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while

leetcode-24Swap Nodes in Pairs

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode swapPairs(L

leetcode-23Merge k Sorted Lists

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode mergeKLists

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

POJ1631最长单调递增子序列

最长单调递增子序列 import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWriter;import java.math.BigInteger;import java.util.StringTokenizer;publ