题解 | 牛舍的占地面积

牛舍的占地面积

https://www.nowcoder.com/practice/4d9d9bf23d874688aee6fc1ac5bf6902

单调递增栈中。

  1. 当前元素压栈时,上一个元素是该元素向前找的第一个小值。
  2. 当前元素出栈时,与其做比较的元素是该元素向后找的第一个小值。
  3. 遍历结束后,因为所有元素都经历了压栈。所以向前找的第一个小值都已经知道(无论是不是边界哦)。当前栈中元素的右边第一个小值都是后边界。

import java.util.*;


public class Solution {
    public int maxArea(int[] areas) {
        final int n = areas.length;
        if (n == 0) {
            return 0;
        }
        int[] l = new int[n];
        int[] r = new int[n];
        Deque<Integer> stack = new ArrayDeque<>();
        for (int i = 0; i < n; ++i) {
            while (!stack.isEmpty() && areas[stack.getLast()] >= areas[i]) {
                r[stack.removeLast()] = i;
            }
            if (stack.isEmpty()) {
                l[i] = -1;
            } else {
                l[i] = stack.getLast();
            }
            stack.addLast(i);
        }
        while (!stack.isEmpty()) {
            r[stack.removeLast()] = n;
        }

        int ans = 0;
        for (int i = 0; i < n; i++) {
            ans = Math.max(ans, (r[i] - l[i] - 1) * areas[i]);
        }
        return ans;
    }
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
06-05 15:27
点赞 评论 收藏
分享
牛客773130651号:巨佬,简历模板换成上下的,左右的很烦,hr看着不爽。。。科大随便乱杀,建议能保研就保研,不行也得考一下 ,985硕去干算法,比开发强多了。开发许多双非都能搞,学历优势用不上,算法有门槛
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务