算法笔记--最大连续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;
    }
}
相关推荐
wabs6663 小时前
关于贪心算法的思考
算法·贪心算法
社交怪人3 小时前
【判断大小】信息学奥赛一本通C语言解法(题号1043)
算法
lengxuemo3 小时前
ICC2学习笔记之Placement and Optimization
笔记·学习
Snasph3 小时前
GNU Make 用户手册(中文版)
服务器·算法·gnu
江澎涌4 小时前
拆解与 AI 的一次对话
人工智能·算法·程序员
sheeta19984 小时前
LeetCode 每日一题笔记 日期:2026.06.02 题目:3635. 最早完成陆地和水上游乐设施的时间 II
笔记·算法·leetcode
Lsk_Smion4 小时前
力扣实训 _ [102].层序遍历--前序--后续_递归与非递归的实现
数据结构·算法·leetcode
小满Autumn5 小时前
MVVM Light 架构笔记:定位器、命令、消息与 IoC 实践
笔记·学习·架构·c#·上位机·mvvm
小欣加油6 小时前
leetcode3751 范围内总波动值I
java·数据结构·c++·算法·leetcode
kobesdu6 小时前
【ROS2实战笔记-24】ROS2 Launch 实用技巧:条件逻辑与节点动态生成
笔记·ros·slam