力扣-最大连续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;

相关推荐
2301_773730314 分钟前
系统编程—在线商城信息查询系统
c++·html
郝学胜-神的一滴5 分钟前
深入理解Linux中的Try锁机制
linux·服务器·开发语言·c++·程序人生
菜鸟233号11 分钟前
力扣416 分割等和子串 java实现
java·数据结构·算法·leetcode
Swift社区17 分钟前
LeetCode 469 凸多边形
算法·leetcode·职场和发展
chilavert31819 分钟前
技术演进中的开发沉思-298 计算机原理:算法的本质
算法·计算机原理
圣保罗的大教堂20 分钟前
leetcode 1458. 两个子序列的最大点积 困难
leetcode
Dream it possible!22 分钟前
LeetCode 面试经典 150_二分查找_搜索二维矩阵(112_74_C++_中等)
leetcode·面试·矩阵
Aaron158826 分钟前
全频段SDR干扰源模块设计
人工智能·嵌入式硬件·算法·fpga开发·硬件架构·信息与通信·基带工程
求梦82030 分钟前
【力扣hot100题】缺失的第一个正数(12)
数据结构·算法·leetcode
黎雁·泠崖44 分钟前
二叉树实战进阶全攻略:从层序遍历到OJ题深度解析
c语言·数据结构·leetcode