力扣(LeetCode)算法_C++——最大连续 1 的个数 III

给定一个二进制数组 nums 和一个整数 k,如果可以翻转最多 k 个 0 ,则返回 数组中连续 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。

cpp 复制代码
    int longestOnes(vector<int>& nums, int k) {
        int left = 0 , right = 0;
        int len = 0, maxi = 0;
        int n = nums.size();
        for (right = 0 ; right < n ; ++right){
            if (nums[right] == 0){
                if (k > 0) {
                    k--;
                    len++;
                    maxi = max(len, maxi);
                } else{
                    while (nums[left] == 1) {left++;len--;}
                    left++;
                }
            } else {
                len++;
                maxi = max(maxi, len);
            }
        }
        return maxi;
    }
相关推荐
wanghu20243 分钟前
ABC460_E题题解
c++·算法
z200509304 分钟前
今日算法(回溯子集)
数据结构·算法·leetcode
Hesionberger7 分钟前
巧用异或找出唯一数字(多解)
java·数据结构·python·算法·leetcode
变量未定义~19 分钟前
阶乘的约数和、斐波那契数列、数列区间最大值(ST表)
数据结构·算法
智者知已应修善业23 分钟前
【51单片机象棋快棋赛 电子裁判器】2023-12-27
c++·经验分享·笔记·算法·51单片机
晚风予卿云月29 分钟前
二分算法练习
数据结构·c++·算法·竞赛·算法随笔
菜菜的顾清寒34 分钟前
力扣HOT100(47) 二叉树的层序遍历
算法·leetcode·深度优先
周末也要写八哥35 分钟前
牛顿迭代Python代码实现
算法
KaMeidebaby1 小时前
卡梅德生物技术快报|基因测序技术在 46,XY 性发育障碍变异筛查中的流程与数据分析
服务器·前端·数据库·人工智能·算法·数据挖掘·数据分析
ZengLiangYi1 小时前
SourceAdapter 插件架构详解
javascript·算法·架构