博客
关于我
滑动窗口的最大值(Java实现)
阅读量:640 次
发布时间:2019-03-14

本文共 1730 字,大约阅读时间需要 5 分钟。

为了解决这个问题,我们需要生成一个数组,其中每个元素对应一个窗口的最大值。窗口从数组的最左边滑动到最右边,每次向右滑动一个位置。为了高效地实现这个功能,我们可以使用双端队列来维护窗口中的最大值。

方法思路

我们可以使用双端队列来维护当前窗口中的最大值。具体步骤如下:

  • 初始化一个双端队列来存储窗口中元素的索引。
  • 遍历数组中的每一个元素。
  • 对于当前元素,先弹出队列中所有小于等于当前元素的元素,因为这些元素不再是当前窗口中的最大值。
  • 将当前元素的索引加入队列。
  • 如果当前索引超过了窗口大小减一,弹出队列中最左边的元素,因为窗口向右滑动了一步。
  • 当窗口完全形成时(即当前索引等于窗口大小减一),记录当前窗口的最大值,即队列的第一个元素的值。
  • 将记录的最大值添加到结果数组中。
  • 这种方法的时间复杂度为O(n),其中n是数组的长度,效率非常高。

    解决代码

    import java.util.LinkedList;public class Test3 {    public static int[] getMaxWindow(int[] arr, int w) {        int[] res = new int[arr.length - w + 1];        if (arr == null || w < 1 || arr.length < w) {            return null;        }        LinkedList
    qmax = new LinkedList<>(); int index = 0; for (int i = 0; i < arr.length; i++) { // 移除所有比当前元素小或等于的元素 while (!qmax.isEmpty() && arr[qmax.peekLast()] <= arr[i]) { qmax.pollLast(); } // 添加当前元素的索引到队列中 qmax.add(i); // 如果窗口已经滑动到了右边的边缘 if (i >= w - 1) { // 移除左边超出窗口范围的元素 if (qmax.peekFirst() <= i - w) { qmax.pollFirst(); } // 记录当前窗口的最大值 res[index++] = arr[qmax.peekFirst()]; } } return res; } public static void main(String[] args) { int[] arr = {4, 3, 5, 4, 3, 3, 6, 7}; int w = 3; System.out.println(Arrays.toString(getMaxWindow(arr, w))); }}

    代码解释

  • 初始化:创建一个双端队列qmax来存储窗口中元素的索引,并初始化结果数组res。
  • 边界检查:确保输入数组不为空,窗口大小大于0,并且数组长度至少为窗口大小。
  • 遍历数组:对于每个元素,首先弹出队列中所有小于等于当前元素的元素,因为这些元素不再是当前窗口中的最大值。
  • 添加元素索引:将当前元素的索引添加到队列中。
  • 滑动窗口:如果当前索引超过了窗口大小减一,弹出队列中最左边的元素,因为窗口向右滑动了一步。
  • 记录最大值:当窗口完全形成时,记录当前窗口的最大值,即队列的第一个元素的值,并添加到结果数组中。
  • 这种方法高效地维护了窗口中的最大值,确保了在每次滑动窗口时都能快速得到最大值。

    转载地址:http://gaulz.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>