力扣-最大连续1的个数III

思路分析

用「左右指针」维护一个滑动窗口,窗口内允许包含最多 k 个 0(翻转成 1 后就是全 1 子数组),通过调整窗口的左右边界,找到满足条件的最大窗口长度:

  • 右指针右移:遍历数组,逐个将元素纳入窗口,统计窗口内 0 的数量zeroCount;
  • 左指针右移:当zeroCount > k时,说明窗口内 0 的数量超过允许翻转的次数,需要右移左指针,直到zeroCount ≤ k;
    更新最大长度:每轮遍历都计算当前窗口长度(right - left + 1),并更新全局最大值。

代码实现

java 复制代码
public int longestOnes(int[] nums, int k) {
        // 定义左右指针
        int left = 0, right = 0;
        // 定义最大长度
        int maxLength = 0;
        // 定义0的数量
        int zeroNum = 0;
        while (right < nums.length){
            // 更新零的数量
            if (nums[right] == 0) {
                zeroNum++;
            }
            while (zeroNum > k){
                if (nums[left] == 0) {
                    zeroNum--;
                }
                left++;
            }

            maxLength = Math.max(maxLength, right - left + 1);
            ++right;
        }
        return maxLength;
    }

复杂度分析

  • 时间复杂度:O(n) → 每个元素最多被左、右指针各访问一次,总操作次数 2n;
  • 空间复杂度:O(1) → 仅使用常数个变量,无额外空间开销。

实例分析

示例 1:nums = [1,1,1,0,0,0,1,1,1,1,0],k = 2

遍历过程关键步骤:

right=0-2(元素 1,1,1):zeroCount=0 → 窗口长度 3,maxLen=3;

right=3(元素 0):zeroCount=1 ≤2 → 窗口长度 4,maxLen=4;

right=4(元素 0):zeroCount=2 ≤2 → 窗口长度 5,maxLen=5;

right=5(元素 0):zeroCount=3 >2 → 收缩左指针:

left=0(1)→ left++,zeroCount 仍 3;

left=1(1)→ left++,zeroCount 仍 3;

left=2(1)→ left++,zeroCount 仍 3;

left=3(0)→ left++,zeroCount=2;

此时窗口:left=4,right=5 → 长度 2;

right=6-9(元素 1,1,1,1):zeroCount=2 → 窗口长度 = 9-4+1=6,maxLen=6;

right=10(元素 0):zeroCount=3 >2 → 收缩左指针到 5,zeroCount=2 → 窗口长度 = 10-5+1=6;

相关推荐
2401_857918292 分钟前
实时数据处理中的C++应用
开发语言·c++·算法
2401_884563242 分钟前
C++中的装饰器模式实战
开发语言·c++·算法
MicroTech20257 分钟前
微算法科技(NASDAQ :MLGO)抗量子区块链技术:筑牢量子时代的数字安全防线
科技·算法·区块链
.select.7 分钟前
C++ 单例模式
java·c++·单例模式
Ivanqhz9 分钟前
图着色寄存器分配算法(Graph Coloring)
开发语言·javascript·python·算法·蓝桥杯·rust
Elsa️74611 分钟前
洛谷p5718 复习下快速排序和堆排序
数据结构·算法·排序算法
Frostnova丶13 分钟前
LeetCode 3567.子矩阵的最小绝对差
算法·leetcode·矩阵
夏日听雨眠15 分钟前
文件学习9
数据结构·学习·算法
华农DrLai15 分钟前
什么是自动Prompt优化?为什么需要算法来寻找最佳提示词?
人工智能·算法·llm·nlp·prompt·llama
黎阳之光16 分钟前
十五五智赋新程 黎阳之光以AI硬核技术筑造产业数智底座
大数据·人工智能·算法·安全·数字孪生