商品折扣后的最终价格单调栈

给你一个数组 prices ,其中 prices[i] 是商店里第 i 件商品的价格。 商店里正在进行促销活动,如果你要买第 i 件商品,那么你可以得到与 prices[j] 相等的折扣,其中 j 是满足 j > iprices[j] <= prices[i]最小下标 ,如果没有满足条件的 j ,你将没有任何折扣。 请你返回一个数组,数组中第 i 个元素是折扣后你购买商品 i 最终需要支付的价格。

ini 复制代码
输入: prices = [8,4,6,2,3]
输出: [4,2,4,2,3]
java 复制代码
class Solution {
    public int[] finalPrices(int[] prices) {
        int n=prices.length;
        int[] ans=new int[n];
        Deque<Integer> stack=new ArrayDeque<Integer>();
        for(int i=n-1;i>=0;i--){
            while(!stack.isEmpty() && stack.peek()>prices[i]){
                stack.pop();
            }
            ans[i]=stack.isEmpty()?prices[i]:prices[i]-stack.peek();
            stack.push(prices[i]);
        }
        return ans;
    }
}
相关推荐
萝卜白菜。3 分钟前
关于Java EE应用中xml解析类的问题
xml·java·java-ee
一米阳光zw9 分钟前
Spring Boot中使用 MDC实现请求TraceId全链路透传
java·spring boot·后端·traceid·mdc
jerryinwuhan20 分钟前
SVM案例分析
算法·机器学习·支持向量机
王元_SmallA23 分钟前
pgsql:connection failed connection to server at
java·后端
绝无仅有26 分钟前
大厂面试相关文章:深入技术面试中的核心知识点
后端·面试·架构
高山上有一只小老虎28 分钟前
购物消费打折
java·算法
绝无仅有29 分钟前
面试文章:网络协议与redis安全,https协议,TCP三次握手,四次挥手等面试经典问题
后端·面试·架构
tuokuac32 分钟前
@Configuration类中定义的@Bean方法
java
郝学胜-神的一滴43 分钟前
计算机图形中的法线矩阵:深入理解与应用
开发语言·程序人生·线性代数·算法·机器学习·矩阵·个人开发
百锦再1 小时前
第8章 模块系统
android·java·开发语言·python·ai·rust·go