算法笔记--最大连续1的个数Ⅲ

leetcode题目链接:1004. 最大连续1的个数 III

题目描述

给定一个二进制数组 nums 和一个整数 k,如果可以翻转最多 k 个 0 ,则返回 数组中连续 1 的最大个数 。

思路

这里可以转换思路,让题意更加明确:即,求一个最大连续区间,要求该区间中的0的个数最多为k个

这样一来就变成了滑动窗口问题:

滑动窗口右侧right:

  • 遇到1了,就记录当前窗口大小,并记录窗口最大值

  • 遇到0了

    如果当前窗口0的个数不足k个(<K)则更新窗口中0的个数

    如果当前窗口0的个数以满足k个,则强制移动窗口左侧left,直到left"吐出"一个1

代码

java 复制代码
class Solution {
    //转换问题看法:求一个连续最大区间,要求这个区间中0的个数最多为K个
    public int longestOnes(int[] nums, int k) {
        int len = nums.length; //数组长度
        int left=0;
        int right=0;
        int numOfZero = 0;//记录当前区间0的个数
        int maxLen = 0; //记录区间最大长度
        for(;right<len;right++){
            if(nums[right] == 0){//遇到0了
                if(numOfZero < k){//还可以变
                    numOfZero++;
                    maxLen = Math.max(maxLen,right-left+1);//记录最长区间
                }else{//k不够了,刚好numOfZero = k,这时需要left吐一个0出来
                    while(left <= right){
                        if(nums[left] == 0){
                            left++;
                            numOfZero--;
                            if(nums[right] == 0)numOfZero++; //这里把left之前指向的0吐出去后,还要看新的right有没有指向0
                            break;
                        }else{
                            left++;
                        }
                    }
                    maxLen = Math.max(maxLen,right-left+1);//记录最长区间
                }
            }else{//遇到1了
                maxLen = Math.max(maxLen,right-left+1);//记录最长区间
            }
        }
        return maxLen;
    }
}
相关推荐
峰顶听歌的鲸鱼几秒前
16.docker:存储
运维·笔记·docker·容器·云计算
少许极端几秒前
算法奇妙屋(二十一)-两个数组或字符串的dp问题(动态规划)
算法·动态规划·两个数组或字符串的dp问题
草莓熊Lotso几秒前
《算法闯关指南:递归,搜索与回溯算法--递归》--04. 两两交换链表中的结点 ,05.Pow(x,n)
数据结构·算法·链表
week_泽1 分钟前
OpenCV图像拼接实践笔记(第一部分)
人工智能·笔记·opencv
Bruce_kaizy3 分钟前
c++图论——最短路之Johnson算法
开发语言·数据结构·c++·算法·图论
BahTiYar_9 分钟前
ctfshow Web应用安全与防护系列
笔记·web安全
七月七3311 分钟前
半小时搞定GitHub学生认证
笔记·github
蒙奇D索大14 分钟前
【数据结构】排序算法精讲 | 交换排序全解:交换思想、效率对比与实战代码剖析
数据结构·笔记·考研·算法·排序算法·改行学it
sin_hielo15 分钟前
leetcode 1351
数据结构·算法·leetcode
睡醒了叭17 分钟前
图像分割-传统算法-边缘分割
图像处理·opencv·算法·计算机视觉