题解 | 牛舍的占地面积

牛舍的占地面积

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;
    }
}

全部评论

相关推荐

头像
04-17 09:29
已编辑
湖南农业大学 后端
睡姿决定发型丫:本硕末9也是0offer,简历挂了挺多,只有淘天 美团 中兴给了面试机会,淘天二面挂,美团一面kpi面,中兴一面感觉也大概率kpi(虽然国企,但一面0技术纯聊天有点离谱吧)
点赞 评论 收藏
分享
05-12 17:00
门头沟学院 Java
king122:你的项目描述至少要分点呀,要实习的话,你的描述可以使用什么技术,实现了什么难点,达成了哪些数字指标,这个数字指标尽量是真实的,这样面试应该会多很多,就这样自己包装一下,包装不好可以找我,我有几个大厂最近做过的实习项目也可以包装一下
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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