首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【数据结构和算法】子数组最大平均数 I

一、题目描述 原题链接:力扣 643 题 子数组最大平均数 I 给你一个由 n 个元素组成的整数数组 nums 和一个整数 k 。...请你找出平均数最大且 长度为 k 的连续子数组,并输出该最大平均数。 任何误差小于 10-5 的答案都将被视为正确答案。...2.1 滑动窗口含义 滑动窗口算法是一种在数组或列表中寻找特定元素的强大工具,可以高效地解决一系列问题。 例如找到一个数组中最大的K个元素、在一个数组中查找子数组的数量等等。...下面将详细介绍滑动窗口算法的工作原理和应用场景: 工作原理: 窗口大小:滑动窗口算法通过设定一个窗口的大小来解决问题。窗口通常是一个连续的子数组或子字符串。...更新解:根据窗口的移动和调整,更新问题的解,并记录或返回所需的结果。 应用场景: 最小/最大子数组/子字符串:寻找给定数组或字符串中满足特定条件的最小或最大的子数组或子字符串。

13310
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Leetcode -643.子数组最大平均值Ⅰ -645.错误的集合】

    Leetcode -643.子数组最大平均值Ⅰ 题目:给你一个由 n 个元素组成的整数数组 nums 和一个整数 k 。 请你找出平均数最大且长度为 k 的连续子数组,并输出该最大平均数。...for (int i = 0; i < k; i++) { sum += nums[i]; } //前 k 项和赋给最大且长度为 k 的连续子数组元素的和...不幸的是,因为数据错误,导致集合里面某一个数字复制了成了集合里面的另外一个数字的值,导致集合丢失了一个数字并且有一个数字重复 。 给定一个数组 nums 代表了集合 S 发生错误后的结果。...请你找出重复出现的整数,再找到丢失的整数,将它们以数组的形式返回。...{ //定义一个hash数组,并初始化为0 int hash[10001] = { 0 }; //记录每个数字出现的次数 for (int i =

    12110

    动态规划 —— 子数组系列-环形子数组的最大和

    环形子数组的最大和 题目链接: 918....环形子数组的最大和 - 力扣(LeetCode) https://leetcode.cn/problems/maximum-sum-circular-subarray/description/ 2....算法原理 状态表示:以某一个位置为结尾或者以某一个位置为起点 f[i]表示:以i位置为结尾的所有子树中的最大和 g[i]表示:以i位置为结尾的所有子树中的最小和 2....找到f表里的最大值,fmax 2.找到g表里的最小值,gmin, gmin在对比之前要先用sum - gmin再进行比较 在这里我们要考虑数组里全是负数的情况...,比如为{-1,-2,-3},那么fmax的值就是-1,gmin的值就是三个数相加,sum - gmin的结果就为0,这样题目就不允许,所以我们要加上一个判断条件: 当sum和gmin相等的时候说明数组里面的值都是负数

    3700

    学徒考核-计算wes数据的全部外显子的平均测序深度

    如果学徒之后跑流程,那其实前途很有限,所以我安排了一个随机任务,考核他们查资料解决问题的能力。...然后根据CCDS数据库拿到人类全部exon的坐标在生信技能树早期教程我也多次讲解过,如何根据CCDS数据库文件,来制作如下BED格式的人类外显子坐标记录文件: $ head hg38.exon.bed...69099 4 chr1 69090 70007 OR4F5 0 + chr1 69100 69100 4 对exon进行汇总 每个坐标的测序深度取平均值即可...,可以写一个简短的perl脚本,或者直接读入该文件到R语言,总之对20多万个外显子都计算一个平均测序深度即可。...课程内容 1 生信-R语言入门 2 GEO数据库挖掘 3 生信-LINUX基础 4 转录组课题设计和流程分析

    1.2K40

    长度最小的子数组

    长度最小的子数组 给定一个含有n个正整数的数组和一个正整数s ,找出该数组中满足其和 ≥ s的长度最小的连续子数组,并返回其长度。如果不存在符合条件的连续子数组,返回0。...实例 输入: s = 7, nums = [2,3,1,2,4,3] 输出: 2 解释: 子数组 [4,3] 是该条件下的长度最小的连续子数组。...然后继续循环,当sum 的时候尾指针不断右移,因为窗口间的值一直小于给定的s,只有尾指针右移扩大窗口才有可能使窗口间的值的和大于等于s,当窗口间值的和大于s时,那么就使首指针右移用以减小窗口的数量...,只有不断减少窗口的数量才能获得长度最小的连续子数组,当尾指针达到边界条件即尾指针超过了nums数组的长度,那么尾指针不再右移,此时将首指针不断右移,直到首指针的长度与nums数组的长度相等,结束循环,...在最后判断target是否仍然等于无穷大,如果仍然是等于无穷大则认为没有找到合适的子数组长度并返回0,否则就返回target。

    1.8K10

    数组——209.长度最小的子数组

    1 题目描述 长度最小的子数组 给定一个含有 n 个正整数的数组和一个正整数 target 。...找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl+1, …, numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0 。...2 题目示例 示例 1: 输入:target = 7, nums = [2,3,1,2,4,3] 输出:2 解释:子数组 [4,3] 是该条件下的长度最小的子数组。...首先要思考 如果用一个for循环,那么应该表示 滑动窗口的起始位置,还是终止位置。 如果只用一个for循环来表示 滑动窗口的起始位置,那么如何遍历剩下的终止位置?...解题的关键在于 窗口的起始位置如何移动 滑动窗口的精妙之处在于根据当前子序列和大小的情况,不断调节子序列的起始位置。

    1.7K70

    连续子数组的最大和

    , A[n]),这个数组有很多连续子数组,那么其中数组之和的最大值是什么呢?...子数组必须是连续的。...要求时间复杂度O(n) 解题思路 方法一:暴力枚举子数组 思路 一个长度为n的数组,共有n(n+1)/2个子数组,计算出所有子数组的和,最快需要O(n^2)的时间复杂度,虽然完成了计算,但是时间复杂度不符合...方法二:找规律 思路 思路如原书给出的如下表格,主要思想是: 记录两个数,最大的子数组和+累加子数组和 遍历数组,随时更新最大的子数组和 一旦累加数为负数,直接放弃,将累加子数组和设置为0 ?...~ 拓展问题 最大子矩阵问题 给定一个矩阵(二维数组),其中数据有大有小,请找一个子矩阵,使得子矩阵的和最大,并输出这个和。

    91420
    领券