寒假打卡: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;
    }
}
相关推荐
happygrilclh6 分钟前
赚外快了:等离子表面处理机电源算法需求说明
算法
ji1985944320 分钟前
MATLAB 求散点曲线斜率
开发语言·算法·matlab
kaikaile199525 分钟前
MATLAB 实现:Koch & Zhao 图像水印算法(DCT域)
开发语言·算法·matlab
love_muming27 分钟前
链表每日一练
java·开发语言·数据结构·链表·idea·每日一练
QiLinkOS27 分钟前
QiLink开源生态的三维重构:基于时间、空间与社会价值的底层规则创新白皮书
大数据·c++·人工智能·科技·算法·gitee·开源
牛肉在哪里34 分钟前
ros2 从零开始28 监听广播C++
开发语言·c++·算法·机器人
玖玥拾36 分钟前
C/C++ 数据结构(二)双向链表
c语言·数据结构·c++
乐观勇敢坚强的老彭39 分钟前
GESP一级核心算法:循环与条件判断的结合
java·数据结构·算法
noipp42 分钟前
推荐题目:洛谷 P1737 [NOI2016] 旷野大计算
linux·数据结构·算法
QiLinkOS1 小时前
极客精神与商业思维的融合实践(2)
c语言·c++·人工智能·算法·开源协议