题解 | #滑动窗口的最大值#

滑动窗口的最大值

https://www.nowcoder.com/practice/1624bc35a45c42c0bc17d17fa0cba788

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param num int整型一维数组
     * @param size int整型
     * @return int整型ArrayList
     */
    public ArrayList<Integer> maxInWindows (int[] num, int size) {
        // write code here
        // 比较最后一个元素和当前最大元素的大小,如果大于就存储,小于就存一个当前最大元素
        ArrayList<Integer> res = new ArrayList<>();
        if (size == 0 || num == null || num.length == 0 || num.length < size) {
            return res;
        }
        ArrayList<Integer> stack = new ArrayList<>();
        if (size == 1) {
            for (int i = 0; i < num.length; ++i) {
                res.add(num[i]);
            }
            return res;
        }
        if (num.length == 1) {
            res.add(num[0]);
            return res;
        } else if (num.length == 2) {
            res.add(num[0] > num[1] ? num[0] : num[1]);
            return res;
        } else {
            int maxx = num[0];
            for (int i = 0; i < size; ++i) {
                stack.add(num[i]);
                if (num[i] > maxx) {
                    maxx = num[i];
                }
            }
            // maxx = Math.max(stack.get(2), Math.max(stack.get(0), stack.get(1)));
            res.add(maxx);
            System.out.println(maxx);
            for (int i = size; i < num.length; ++i) {
                stack.add(num[i]);
                stack.remove(0);

                if (stack.contains(maxx)) {
                    if (num[i] > maxx) {
                        maxx = num[i];
                        res.add(num[i]);
                    } else {
                        res.add(maxx);
                    }
                    System.out.println(":" + maxx);
                } else {
                    maxx = Math.max(stack.get(2), Math.max(stack.get(0), stack.get(1)));
                    res.add(maxx);
                }

            }
        }
        return res;
    }
}

全部评论

相关推荐

03-10 11:23
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 长得好看会提高面试通过率吗? #
3423次浏览 43人参与
# HR最不可信的一句话是__ #
1038次浏览 32人参与
# MiniMax求职进展汇总 #
25003次浏览 321人参与
# 春招至今,你的战绩如何? #
15286次浏览 141人参与
# AI面会问哪些问题? #
911次浏览 22人参与
# 你的实习产出是真实的还是包装的? #
2862次浏览 52人参与
# 巨人网络春招 #
11500次浏览 224人参与
# 沪漂/北漂你觉得哪个更苦? #
1361次浏览 40人参与
# 你做过最难的笔试是哪家公司 #
1161次浏览 20人参与
# AI时代,哪个岗位还有“活路” #
2736次浏览 50人参与
# XX请雇我工作 #
51149次浏览 171人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7982次浏览 43人参与
# 简历第一个项目做什么 #
32100次浏览 359人参与
# 简历中的项目经历要怎么写? #
310955次浏览 4260人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152854次浏览 889人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187566次浏览 1123人参与
# AI时代,哪些岗位最容易被淘汰 #
64582次浏览 867人参与
# 如果重来一次你还会读研吗 #
229990次浏览 2011人参与
# 投格力的你,拿到offer了吗? #
178284次浏览 891人参与
# 你怎么看待AI面试 #
180699次浏览 1298人参与
# 正在春招的你,也参与了去年秋招吗? #
364256次浏览 2641人参与
# 腾讯音乐求职进展汇总 #
160831次浏览 1114人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务