寒假打卡:2026-2-8

日常学习:(算法)

最⼤连续 1 的个数:

给定一个二进制数组 nums 和一个整数 k,假设最多可以翻转 k0 ,则返回执行操作后 数组中连续 1 的最大个数

示例 1:

复制代码
输入:nums = [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]
粗体数字从 0 翻转到 1,最长的子数组长度为 6。

示例 2:

复制代码
输入:nums = [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]
粗体数字从 0 翻转到 1,最长的子数组长度为 10。

算法思想--->动态窗口

求数组中⼀段最⻓的连续区间,要求这段区间内 0 的个数不超过 k 个。

  1. 初始化⼀个⼤⼩为 2 的数组就可以当做哈希表 hash 了;初始化⼀些变量 left = 0 ,
    right = 0 , ret = 0 ;
  2. 当 right ⼩于数组⼤⼩的时候,⼀直下列循环:
  • 让当前元素进⼊窗⼝,顺便统计到哈希表中;
  • 检查 0 的个数是否超标:
    • 如果超标,依次让左侧元素滑出窗⼝,顺便更新哈希表的值,直到 0 的个数恢复正
      常;
  • right++ ,处理下⼀个元素;

代码实现:

java 复制代码
class Solution {
    public int longestOnes(int[] nums, int k) {
        int ret=0,n=nums.length;
        for(int left=0,right=0,zero=0;right<n;right++){
            if(nums[right]==0){
                zero++;//进窗口
            }
            while(zero>k){//判断
                if(nums[left++]==0){
                    zero--;//出窗口
                }
            }
            ret=Math.max(ret,right-left+1);
        }
        return ret;
    }
}
相关推荐
Liu6288817 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
AI科技星17 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘
条tiao条18 小时前
KMP 算法详解:告别暴力匹配,让字符串匹配 “永不回头”
开发语言·算法
干啥啥不行,秃头第一名18 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
tobias.b18 小时前
计算机基础知识-数据结构
java·数据结构·考研
zzh9407718 小时前
Gemini 3.1 Pro 硬核推理优化剖析:思维织锦、动态计算与国内实测
算法
2301_8073671919 小时前
C++中的解释器模式变体
开发语言·c++·算法
愣头不青19 小时前
617.合并二叉树
java·算法
MIUMIUKK19 小时前
双指针三大例题
算法
灵感__idea19 小时前
Hello 算法:复杂问题的应对策略
前端·javascript·算法