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

【优选算法】11----最大连续1的个数|||

题目解析: 讲解算法原理: 这道题目可以使用滑动窗口算法来解决。滑动窗口的核心思想是通过维护一个窗口,使得窗口内的 0的个数不超过k,然后不断移动窗口的左右边界来找到最长的连续1子数组。...通过滑动窗口算法,我们可以高效地解决这个问题。滑动窗口算法的关键在于维护一个满足条件的 窗口,并通过移动窗口的边界来找到最优解。...在这道题目中,我们通过维护一个窗口使得窗口内的 0的个数不超过k,从而找到了最长的连续1子数组。...} } ret=max(ret,right-left+1); } return ret; } }; 有兴趣的铁子可以参照我的思路来做一遍哦...最大连续1的个数 III - 力扣(LeetCode)

1900

寻找最大的K个数

给你n个数,让你找出其中最大的K个数。 解法1: 很多人上来就对其进行排序,选用不同的排序方法有不同的时间复杂度,这里我们假设使用了最快的快排,时间复杂度为O(n*logn)。...通过排序我摘出前K大的数。 但也许快排不是最优的,我们只找最大的K个数,何必要对所有的数进行排序,我们只需要进行局部排序即可,时间复杂度大概是O(N*K)。...在这里,我们只要在递归过程中选包含最大的K个数的部分进行完整的快排,而对于其他的部分只进行快排的一部分。 关于使用快排求第K大数的方法参见其他博文。...在这个基础上,只需要做小小的改进就可以完成寻找最大K个数的功能了,时间复杂度O(N)。...结果遍历所有元素后,我们都得到保存最大K个数的堆,也就到达了我们的目的。

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

    【数据结构和算法】最大连续1的个数 III

    一、题目描述 给定一个二进制数组 nums 和一个整数 k,如果可以翻转最多 k 个 0 ,则返回 数组中连续 1 的最大个数 。...当 A[right] 为 0,说明滑动窗口内增加了一个 0; left 被动右移:判断此时窗口内 0 的个数,如果超过了 K,则 left 指针被迫右移,直至窗口内的 0 的个数小于等于 K 为止。...滑动窗口长度的最大值就是所求。 2.2 滑动窗口解题模板 滑动窗口算法是一种常用的算法,用于解决数组或列表中的子数组问题。...下面是一个滑动窗口算法的解题模板: 定义窗口大小:首先需要确定滑动窗口的大小,即每次滑动时包含的元素个数。 初始化窗口:将窗口的起始位置设置为0,窗口大小设置为n,其中n为数组或列表的长度。...下面是一个具体的例子,使用滑动窗口算法求解数组中连续子数组的最大和: def maxSubArray(nums): if not nums: return 0

    20610

    【优选算法】——滑动窗口——1004. 最大连续1的个数 III

    最大连续1的个数 III 给定一个二进制数组 nums 和一个整数 k,如果可以翻转最多 k 个 0 ,则返回 数组中连续 1 的最大个数 。...提示: 1 <= nums.length <= 105 nums[i] 不是 0 就是 1 0 <= k <= nums.length 2.解法(滑动窗⼝): 算法思路: 不要去想怎么翻转,不要把问题想的很复杂...因此,我们可以把问题转化成:求数组中⼀段最⻓的连续区间,要求这段区间内 0 的个数不超 过 k 个。既然是连续区间,可以考虑使⽤「滑动窗⼝」来解决问题。 算法流程: a....检查 0 的个数是否超标: • 如果超标,依次让左侧元素滑出窗⼝,顺便更新哈希表的值,直到 0 的个数恢复正 常; iii....2.图解 3.代码实现 1.C语言 // 辅助函数,返回两个整数的最大值 int max(int a, int b) { return (a > b) ?

    7510

    求一个数组的最大k个数(java)

    问题描述:求一个数组的最大k个数,如,{1,5,8,9,11,2,3}的最大三个数应该是,8,9,11 问题分析:     1.解法一:最直观的做法是将数组从大到小排序,然后选出其中最大的K个数,但是这样的解法...2.解法二:不对前K个数进行排序,回忆快排的算法中,那个partition函数,就是随机选择数组中的一个数,把比这个数大的数,放在数组的前面,把比这个数小的数放在数组的 后面,这时想如果找出的随机数,最终位置就是...K,那么最大的K个数就找出来了,沿着这个思路思考问题,但是这个函数,最后的索引位置并不一定是K,可能比K大也可能比K小,我们把找出的数组分成两部分sa,sb,sa是大的部分,sb是小的部分,如果sa的长度等于...K中元素的一部分,再从sb中找到,k-m个最大的元素,组合起来就是最终的结果,那么这时把问题简化成从sb中找k-m个最大的元素,所以总体来说这是一个递归的过程,虽然复杂大也是O(n*logn)但是,每一次数据量都会减少所以会更加的快...3.解法三:是利用堆排序,建立一个K阶最大堆,然后数据一个个插入队当中,那么插入队的时间复杂度是O(logK),适合数据量比较大的时候,用堆的效果更加好。

    86620

    每日算法系列【LeetCode 1004】最大连续1的个数 III

    题目描述 给定一个由若干 0 和 1 组成的数组 A ,我们最多可以将 K 个值从 0 变成 1 。 返回仅包含 1 的最长(连续)子数组的长度。...示例1 输入: A = [1,1,1,0,0,0,1,1,1,1,0], K = 2 输出: 6 解释: [1,1,1,0,0,1,1,1,1,1,1] A[5] 和 A[10] 从 0 翻转到 1,最长的子数组长度为...0,0,1,1,0,0,1,1,1,0,1,1,0,0,0,1,1,1,1], K = 3 输出: 10 解释: [0,0,1,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,1] A[4] 、A[5]...过程中时刻更新最长的距离 res 。 因为 l 和 r 分别最多移动 n 次,所以最终的时间复杂度是 的。 那么为什么这样是正确的呢?不会漏掉正确答案所在的区间吗?我们看看漏掉的是哪些区间。...对于一个固定的 r ,移动 l 直到 0 的数量小于等于 K (记为 l' )的过程中,漏掉的是 [l', r] 这些区间。

    1.1K10

    求一个数组中子数组的最大和算法(Java实现)

    前几天在微信订阅号“待字闺中”中看到的一篇文章《小技巧求一个数组中子数组的最大和》,提供下Java的实现,并且在对题目做下小修改,本来打算直接在微信里直接回复,但是发现无法回复,然后整理出一篇简短博客吧...原题及解答     来自《小技巧求一个数组中子数组的最大和》;     题目:     输入一个整形数组,数组里有正数也有负数。数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。...例如输入的数组为 1, -2, 3, 10, -4, 7, 2, -5,和最大的子数组为 3, 10, -4,7, 2, 因此输出为该子数组的和 18。  ...解答:  【只有子数组“前半部分”的和为正数时,子数组的求和才有可能最大】,在这个trick条件下,只需要遍历一次数组就可以。算法是:当从头开始遍历的元素的求和为正数时,继续向后遍历。...当全为正数时,最大的和自然就是所有元素的和,当全为负数时,最大和自然就是其中最大的那个负数的值。通过此算法都能得到相应的结果。

    1.6K80

    【算法千题案例】⚡️每日LeetCode打卡⚡️——59.最大连续 1 的个数

    原题样例:最大连续 1 的个数 ????C#方法:一次遍历 ????Java 方法:一次遍历 ????总结 ????前言 ???? 算法题 ???? ????...原题样例:最大连续 1 的个数 给定一个二进制数组, 计算其中最大连续 1 的个数。...Java 方法:一次遍历 思路解析 为了得到数组中最大连续 1 的个数,需要遍历数组,并记录最大的连续 1 的个数和当前的连续 1 的个数。...如果当前元素是 1,则将当前的连续 1 的个数加 1,否则,使用之前的连续 1 的个数更新最大的连续 1 的个数,并将当前的连续 1 的个数清零。...遍历数组结束之后,需要再次使用当前的连续 1 的个数更新最大的连续 1 的个数,因为数组的最后一个元素可能是 111,且最长连续 1 的子数组可能出现在数组的末尾,如果遍历数组结束之后不更新最大的连续

    36730

    三个数的最大乘积

    1 问题 给定一个正数整型数组nums(不考虑有负数的情况),在数组中找出由三个数组装成的最大乘积值,并输出这个乘积。...示例1: 输入:nums=[1,2,3] 输出:6 示例2: 输入:nums=[1,2,3,4] 输出:24 2 方法 在这个数组中,先找出原数组中最大的一个数,放入一个新列表,再将原数组中的该最大数字删去...,下次就可以找到第二个,第三个最大数字,然后将新列表里的三个数相乘,就得到了我们要的最大的三个数组装成的最大乘积。...代码清单 1 nums=[2,3,4,5,6,1] list=[] for i in range(3):#只需要找出三个最大的数,因此遍历3次。...list.append(max(nums)) nums.remove(max(nums)) cj=list[0]*list[1]*list[2] print(cj) 4 结语 针对解决数组中三个数的最大乘积问题

    27520

    【递归】递归求n个数中的最大值

    作者:每天都要记得刷题(●’◡’●) 时间:2022/04/04 本篇感悟:举一反三,由求 n的阶乘联想到递归求n个数中的最大值,对递归有了更深的了解。...文章目录 ⭐题目(代码在文末) ⭐递归思想 ⭐求前n个斐波那契数 ⭐具体代码(答案) ⭐题目(代码在文末) 使用递归求 55 ,22, 155, 77, 99这5个数中的最大值 ⭐递归思想 Q...往里套用就是: 关键:重复把求最大值这个过程重复再重复,知道找到递归出口 1.当数组只有一个元素的时候,这个数就是最大值 2.但是当n>1时,从数组下标大的一端开始自身调用**,将最后一个数和n-...1个数中的最大值进行比较(假设我们已知)** 3.然后就是求n-1个数中的最大值,也就是重复了以上的步骤 4.知道我们到了递归出口,再归回去就可以了。...a[n - 1] : find_max(a, n - 1); } int main() { //递归求n个数中的最大值 int a[5] = { 55,22,155,77,99 }; int

    1.3K20
    领券