Leetcode 最大连续 1 的个数 III(medium)

题目链接:1004. 最大连续 1 的个数 III

2. 题目描述:

3. 解法(滑动窗口):

算法思路:

不要去想怎么翻转,不要把问题想的很复杂,这道题的结果无非就是一段连续的 1 中间塞了 k

个 0 嘛。

因此,我们可以把问题转化成:求数组中一段最长的连续区间,要求这段区间内 0 的个数不超

过 k 个。

既然是连续区间,可以考虑使用「滑动窗口」来解决问题

算法流程:

a. 初始化一个大小为 2 的数组就可以当做哈希表 hash 了;初始化一些变量 left = 0 ,

right = 0 , ret = 0 ;

b. 当 right 小于数组大小的时候,一直下列循环:

i. 让当前元素进入窗口,顺便统计到哈希表中;

ii. 检查 0 的个数是否超标:

• 如果超标,依次让左侧元素滑出窗口,顺便更新哈希表的值,直到 0 的个数恢复正

常;

iii. 程序到这里,说明窗口内元素是符合要求的,更新结果;

iv. right++ ,处理下一个元素;

c. 循环结束后, ret 存的就是最终结果。

C++ 算法代码:

cpp 复制代码
class Solution
{
public:
    int longestOnes(vector<int>& nums, int k)
    {
        int ret = 0;
        for(int left = 0, right = 0, zero = 0; right < nums.size(); right++)
        {
            if(nums[right] == 0) zero++; // 进窗口
            while(zero > k) // 判断
            if(nums[left++] == 0) zero--; // 出窗口
            ret = max(ret, right - left + 1); // 更新结果
        }
        return ret;
    }
};

C++ 代码结果:

Java 算法代码:

java 复制代码
class Solution
{
    public int longestOnes(int[] nums, int k)
    {
        int ret = 0;
        for(int left = 0, right = 0, zero = 0; right < nums.length; right++)
        {
            if(nums[right] == 0) zero++; // 进窗口
            while(zero > k) // 判断
            if(nums[left++] == 0) zero--; // 出窗口
            ret = Math.max(ret, right - left + 1); // 更新结果
        }
        return ret;
    }
}

Java 运行结果:

相关推荐
Navigator_Z7 小时前
LeetCode //C - 1089. Duplicate Zeros
c语言·算法·leetcode
云泽80810 小时前
C++ 可调用对象通关指南:深度解析 Lambda 表达式、function 包装器与 bind 绑定器
开发语言·c++·算法
wlsh1510 小时前
Go 迭代器
算法
语戚11 小时前
力扣 3161. 块放置查询:线段树解法(Java 实现)
java·算法·leetcode·面试·线段树·力扣·
天天进步201511 小时前
Python全栈项目实战:从零构建校园心理健康咨询平台
面试·职场和发展
CS创新实验室11 小时前
从顺序表到动态数组:数据结构的永恒基石与现代语言的优雅封装
数据结构·算法
Black蜡笔小新12 小时前
自动化AI算法训练服务器DLTM训推一体化平台助力农业生产管理实现安全智能化
人工智能·算法·自动化
武子康12 小时前
调查研究-151 Slack vs Jira:区别、使用指南与团队选择方法
人工智能·科技·深度学习·ai·职场和发展·jira·slack
8Qi813 小时前
LeetCode 23. 合并 K 个升序链表 —— 小顶堆(PriorityQueue)
数据结构·算法·leetcode·链表·
QiLinkOS13 小时前
《打破“用爱发电”:一种基于 Gitee 与时间戳的开源权益分配机制探索》
c语言·数据结构·c++·科技·算法·gitee·开源