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

相关推荐
Thera77729 分钟前
【Linux C++】彻底解决僵尸进程:waitpid(WNOHANG) 与 SA_NOCLDWAIT
linux·服务器·c++
Wei&Yan33 分钟前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
wregjru1 小时前
【QT】4.QWidget控件(2)
c++
浅念-1 小时前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
小羊不会打字1 小时前
CANN 生态中的跨框架兼容桥梁:`onnx-adapter` 项目实现无缝模型迁移
c++·深度学习
团子的二进制世界1 小时前
G1垃圾收集器是如何工作的?
java·jvm·算法
Max_uuc1 小时前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++
吃杠碰小鸡1 小时前
高中数学-数列-导数证明
前端·数学·算法
故事不长丨1 小时前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
long3161 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法