算法笔记--最大连续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;
    }
}
相关推荐
AI小老六9 分钟前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考15 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队18 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
RainCity1 天前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK2 天前
线段树维护区间 k 次方和
c++·数学·算法·stl