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

给你一个数组 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;
    }
}
相关推荐
Moment2 分钟前
小米不仅造车,还造模型?309B参数全开源,深度思考完胜DeepSeek 🐒🐒🐒
前端·人工智能·后端
Tadas-Gao3 分钟前
存储技术革命:SSD、PCIe与NVMe的创新架构设计与性能优化
java·性能优化·架构·系统架构·存储
codergjw12 分钟前
常见面试题
java
马卡巴卡12 分钟前
SpringBoot集成Spring Statemachine(状态机)实战教程
后端
咕噜企业分发小米13 分钟前
如何平衡服务器内存使用率和系统稳定性?
java·服务器·前端
李子园的李14 分钟前
函数式编程与传统编程的对比——基于java
java
爬山算法15 分钟前
Netty(13)Netty中的事件和回调机制
java·前端·算法
酒酿萝卜皮19 分钟前
Elastic Search 安装使用
后端
CoovallyAIHub21 分钟前
是什么支撑L3自动驾驶落地?读懂AI驾驶与碰撞预测
深度学习·算法·计算机视觉
玉树临风ives28 分钟前
atcoder ABC436 题解
c++·算法·leetcode·atcoder·信息学奥赛