当前位置: 首页 > ai >正文

【算法】滑动窗口(细节探究,易错解析)5.21

接上节

需求:
给你一个由 n 个元素组成的整数数组 nums 和一个整数 k 。
请你找出平均数最大且 长度为 k 的连续子数组,并输出该最大平均数。

示例 1:
输入:nums = [1,12,-5,-6,50,3], k = 4
输出:12.75
解释:最大平均数 (12-5-6+50)/4 = 51/4 = 12.75

示例 2:
输入:nums = [5], k = 1
输出:5.00000

方式一
使用双循环

class Solution {public double findMaxAverage(int[] nums, int k) {double ans=Integer.MIN_VALUE;double avg=0;double sum=0;if(nums==null||nums.length<k){return 0;}for(int j=0;j<=nums.length-k;j++){sum=0.0;for(int i=j;i<k+j;i++){sum+=nums[i];}avg=sum/k;ans=Math.max(ans,avg);}return ans;}
}

易错点:
①ans代表平均数最大值,如果赋值为0,当数组为复数时,会返回0报错。
在这里插入图片描述
所以ans应该赋值为Integer.MIN_VALUE(代表最小值)。
②sum要重置,如果不重置,每次都会累加上一组循环的值。
③j的循环要保证包括k边界,
j<=nums.length-k或j-k+1<nums.length
④需要判断数组长度是否大于k,否则返回0。
⑤double类型也要注意

方式二
滑动窗口

class Solution {public double findMaxAverage(int[] nums, int k) {double ans=Integer.MIN_VALUE;double sum=0;for(int i=0;i<nums.length;i++){sum+=nums[i];if(i<k-1){continue;}ans=Math.max(ans,sum);sum-=nums[i-k+1];}return ans/k;}
}

说明:
①continue的作用,如果不足k个元素,就不会执行下面的操作,保证满足数组k的长度。
②更新最大值
③sum-=nums[i-j+1]减去出去的元素。

方式三
滑动窗口第二种形式

class Solution {public double findMaxAverage(int[] nums, int k) {int sum = 0;int n = nums.length;for (int i = 0; i < k; i++) {sum += nums[i];}int maxSum = sum;for (int i = k; i < n; i++) {sum = sum - nums[i - k] + nums[i];maxSum = Math.max(maxSum, sum);}return 1.0 * maxSum / k;}
}

说明:
①先得到第一组数组的和
②通过遍历更新数组

http://www.xdnf.cn/news/7881.html

相关文章:

  • Baklib知识中台驱动智能服务创新
  • AbMole| Ferrostatin-1(25322-68-3,M2698,铁抑素-1)
  • pinia的简单使用
  • 家用和类似用途电器的安全 第1部分:通用要求 与2005版差异(7)
  • openlayer:12在某一区县内(一定区域内)加载不同类型的坐标位置,点击后弹出overlay弹窗显示坐标点详细信息,点击弹窗上关闭按钮关闭弹窗
  • 鸿蒙版Flutter库torch_light手电筒功能深度适配
  • 传统Spring MVC + RESTful 与 Vue3 结合 JWT Token 验证的示例
  • 143.重排链表的尝试
  • 数据库表关系详解
  • URL 类知识点详解
  • Python入门手册:正则表达式的学习
  • 代理IP在市场分析与用户画像研究中的应用解析
  • spring cloud alibaba-Geteway详解
  • 禁忌搜索算法:从原理到实战的全解析
  • 现代人工智能系统的实用设计模式
  • Science Advances | MIST:一种新型深度学习框架可解释的单细胞T细胞多组学整合分析工具
  • 基于Java( GUI )实现多人在线聊天软件
  • UE5.6新版本—— 动画光照系统重点更新
  • 3.2.3
  • SMT贴片工厂核心工艺与质量控制解析
  • LeetCode-链表-合并两个有序链表
  • GO语言学习(七)
  • 野火RK3588部署yolov8
  • 【notepad++如何设置成中文界面呢?】
  • 解决使用HBuilder X开发时uView组件不生效的问题
  • python爬虫和逆向:百度翻译数据采集的几种方式
  • Spring Boot AI 之 Chat Client API 使用大全
  • 前端面试题
  • C# AOP编程
  • 【亲测有效】Ubuntu22.04安装黑屏重启进入系统卡死