962. Maximum Width Ramp
本题题意:
在数组中,找到最大的j-i,使得i<j and A[i] <= A[j]
思路:
维持一个递减的栈,遇到比栈顶小的元素,进栈;
比大于等于栈顶的元素-> 找到栈中第一个小于等于该元素的下标
时间:O(Nlgn),空间:O(N)
List<Integer> s = new ArrayList<>();
        int res = 0;
        for (int i = 0; i < A.length; i++){
            if (s.isEmpty() || A[ s.get(s.size() - 1) ] > A[i]){
                s.add(i);
            }else{
                int left = 0, right = s.size() - 1;
                int mid = 0;
                while (left < right){
                    mid = (left + right) / 2;
                    if (A[s.get(mid)] > A[i]){
                        left = mid + 1;
                    }else{
                        right = mid;
                    }
                }
                res = Math.max(res, i - s.get(left));
            }
        }
进一步的栈利用:
    Stack<Integer> s = new Stack<>();
        int res = 0;
        for (int i = 0; i < A.length;i++){
            if (s.isEmpty() || A[s.peek()] > A[i]){
                s.add(i);
            }
        }
        for (int i = A.length - 1; i > res; i--){
            while (!s.isEmpty() && A[s.peek()] <= A[i]){
                res = Math.max(res, i - s.pop());
            }
        }
        return res;
962. Maximum Width Ramp的更多相关文章
- LC 962. Maximum Width Ramp
		Given an array A of integers, a ramp is a tuple (i, j) for which i < j and A[i] <= A[j]. The ... 
- 【leetcode】962. Maximum Width Ramp
		题目如下: Given an array A of integers, a ramp is a tuple (i, j) for which i < j and A[i] <= A[j]. ... 
- 【LeetCode】962. Maximum Width Ramp 解题报告(Python)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 单调栈 日期 题目地址:https://leetco ... 
- [Swift]LeetCode962. 最大宽度坡 | Maximum Width Ramp
		Given an array A of integers, a ramp is a tuple (i, j) for which i < j and A[i] <= A[j]. The ... 
- Maximum Width Ramp LT962
		Given an array A of integers, a ramp is a tuple (i, j) for which i < j and A[i] <= A[j]. The ... 
- 116th LeetCode Weekly Contest Maximum Width Ramp
		Given an array A of integers, a ramp is a tuple (i, j) for which i < j and A[i] <= A[j]. The ... 
- 单调栈-Maximum Width Ramp
		2020-01-23 19:39:26 问题描述: 问题求解: public int maxWidthRamp(int[] A) { Stack<Integer> stack = new ... 
- [LeetCode] Maximum Width of Binary Tree 二叉树的最大宽度
		Given a binary tree, write a function to get the maximum width of the given tree. The width of a tre ... 
- [Swift]LeetCode662. 二叉树最大宽度 | Maximum Width of Binary Tree
		Given a binary tree, write a function to get the maximum width of the given tree. The width of a tre ... 
随机推荐
- 【nodejs原理&源码赏析(6)】深度剖析cluster模块源码与node.js多进程(下)
			目录 一. 引言 二.server.listen方法 三.cluster._getServer( )方法 四.跨进程通讯工具方法Utils 五.act:queryServer消息 六.轮询调度Roun ... 
- C# 动态加载资源
			在xaml中控件通过绑定静态资源StaticResource来获取样式Style有多种方式,TextBlockStyle.xaml是一个ResourceDictionary,包含了所需样式 通过相对路 ... 
- JQuery javascript实现父子页面相互调用
			javascript实现父子页面相互调用 By:授客 QQ:1033553122 场景1 父页面调用子页面 如上图,在iframe子页面的<script>元素中,定义了taskStatus ... 
- 【前端知识体系-NodeJS相关】对NodeJS模块机制的理解
			1. CommonJS模块规范 1.1 模块引用 var math = require('math'); 1.2 模块定义 [!NOTE] 上下文提供exports对象用于导出当前模块的方法和变量,并 ... 
- numpy中array和matrix的区别
			两者相似但执行相同的运算可能得到不同的结果 显然,array只能通过dot()实现"矩阵乘法",array的"*"运算实现的是两个纬度相同的"矩阵&q ... 
- 数据结构笔记1(c++)_指针
			一.数据结构概述 1.定义: 我们如何把现实中大量而复杂的问题,以特定的数据类型和特定的存储结构保存到主存储器(内存)中,以及在此基础上为实现某个功能(比如查找某个元素,删除某个元素,对所有元素进行排 ... 
- Maven为项目配置仓库
			Maven为项目配置仓库 参考 https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933541&idx=1&s ... 
- Codeforces Round #603 (Div. 2) C. Everyone is a Winner! 二分
			C. Everyone is a Winner! On the well-known testing system MathForces, a draw of n rating units is ar ... 
- Java连载53-单例模式初步、final关键字补充、回顾知识点
			一.回顾 1.类和对象的区别 2.UML(uniform makeup language) 3.方法区存储静态变量.常量(static final修饰) 4.堆内存中存储对象 5.栈存储变量 6.th ... 
- Python连载51-网络编程基础知识
			一.网络编程 1.网络.网络协议(一套规则) 2.网络模型: (1)七层模型-七层 物理层(比如网线.锚).数据链路层(比如电压电流).网络层.传输层.会话层.表示层.应用层(我们的活动基本都在这一层 ... 
