算法笔记--最大连续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;
    }
}
相关推荐
Navigator_Z2 小时前
LeetCode //C - 1089. Duplicate Zeros
c语言·算法·leetcode
sulikey4 小时前
个人Linux操作系统学习笔记6 - 操作系统与进程初识
linux·笔记·学习·操作系统·进程
云泽8084 小时前
C++ 可调用对象通关指南:深度解析 Lambda 表达式、function 包装器与 bind 绑定器
开发语言·c++·算法
XGeFei5 小时前
【Fastapi学习笔记(3)】——资源的层级关系、安全性-幂等性、Field、工厂函数
笔记·学习·fastapi
wlsh155 小时前
Go 迭代器
算法
语戚5 小时前
力扣 3161. 块放置查询:线段树解法(Java 实现)
java·算法·leetcode·面试·线段树·力扣·
CS创新实验室6 小时前
从顺序表到动态数组:数据结构的永恒基石与现代语言的优雅封装
数据结构·算法
星恒随风6 小时前
Python 基础语法详解(一):从表达式、变量到数据类型
开发语言·笔记·python·学习
Black蜡笔小新6 小时前
自动化AI算法训练服务器DLTM训推一体化平台助力农业生产管理实现安全智能化
人工智能·算法·自动化
暴躁小师兄数据学院7 小时前
【AI大数据工程师特训笔记】第14讲:Linux操作系统与shell脚本
大数据·人工智能·笔记