算法刷题:最大连续1的个数

最大连续1的个数

  • .
  • 题目链接
  • 题目详情
  • 题目解析
  • 算法原理
    • 滑动窗口
    • 定义指针和其他变量
    • 进窗口
    • 判断
    • 出窗口
    • 结束
    • 更新结果
  • 我的答案

.

题目链接

最大连续1的个数

题目详情

题目解析

将题目转化为求一个最长的字串,字串中0的个数不能大于k个

算法原理

滑动窗口

这道题采用滑动窗口的思想

定义指针和其他变量

int left = 0,right = 0,//两个同向指针

n = nums.length,//数组长度

zero = 0,//计数器,计算零的个数

ret = 0;//返回值,最长的子串的长度

进窗口

right所指的位置上如果是0,则让计数器加一,并在执行一次逻辑过后向右移动一位

判断

判断当前窗口内零的个数是否大于k

出窗口

如果left当前所指的位置是0,则计数器减一,并跳过当前位置,往右移动一位,然后继续进入判断环节,直到窗口合法

结束

当right到达数组结尾的时候

更新结果

当窗口内的数据处于合法的时候,就可以更新结果

我的答案

java 复制代码
class Solution {
    public int longestOnes(int[] nums, int k) {
        //定义指针
        int left = 0,right = 0,n = nums.length,zero = 0,ret = 0;
        for(;right<n;right++){
            //进窗口
            //如果是0,计数器加1
            if(nums[right]==0) zero++;
            //判断
            while(zero>k){
                //不合法则出窗口
                //如果是0,zero减一,并让left左移
                if(nums[left++]==0) zero--;
            }
            //窗口内数据合法,更新结果
            ret = Math.max(ret,right-left+1);
        }
        //返回结果
        return ret;
    }
}
相关推荐
BlockChain88811 小时前
AI+区块链深度探索:算法与账本的共生时代
人工智能·算法·区块链
生成论实验室11 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第一章 源:不可言说的生成之源
人工智能·科技·算法·生活·创业创新
2zcode11 小时前
基于低光照增强与轻量型CNN道路实时识别算法研究(UI界面+数据集+训练代码)
人工智能·算法·cnn·低光照增强·自动驾驶技术
小雅痞12 小时前
[Java][Leetcode middle] 209. 长度最小的子数组
java·算法·leetcode
做时间的朋友。12 小时前
精准核酸检测
java·数据结构·算法
冯诺依曼的锦鲤12 小时前
从零实现高并发内存池:TCMalloc 核心架构拆解
c++·学习·算法·架构
Thomas_Lee_OR12 小时前
多Agent路径规划 LaCAM for multi-agent path finding (MAPF)
算法·路径规划·仓储机器人·mapf
一切皆是因缘际会12 小时前
可落地数字生命工程:从记忆厮杀到自我意识觉醒全链路,AGI内生智能硅基生命心智建模
人工智能·深度学习·算法·机器学习·ai·系统架构·agi
nlpming12 小时前
opencode Agent 详解
算法
江南十四行12 小时前
排序算法进阶:直接插入排序(简单排序)与希尔排序
数据结构·算法·排序算法