经典滑动窗口试题(一)

📘北尘_个人主页
🌎个人专栏 :《Linux操作系统》《经典算法试题 》《C++》 《数据结构与算法》

☀️走在路上,不忘来时的初心

文章目录


一、将x减到0的最小操作数

1、题目讲解

2、讲解算法原理

3、代码实现

cpp 复制代码
class Solution {
public:
    int minOperations(vector<int>& nums, int x) {
        int n=nums.size(),ret=0,sum=0,target,len=-1;
        for(int i=0;i<n;i++)
            ret+=nums[i];

        target=ret-x;
        if(target<0)  return -1;
    
        for(int left=0,right=0;right<n;right++)
        {
            sum+=nums[right];
            while(sum>target)
                sum-=nums[left++];
                
            if(sum==target)
                len=max(len,right-left+1);
                
        }
       if(len==-1) return len;
       else return n-len;

    }
};

二、无重复的最长子串

1、题目讲解

2、讲解算法原理

3、代码实现

cpp 复制代码
class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        int n=s.size();
        int count[128]={0},len=0;
        for(int left=0,right=0;right<n;right++)
        {
            count[s[right]]++;
            while(count[s[right]]==2)
                count[s[left++]]--;
                
            len=max(len,right-left+1);
        }
        return len;
    }
};

三、最大连续为1的个数

1、题目讲解

2、讲解算法原理

3、代码实现

cpp 复制代码
class Solution {
public:
    int longestOnes(vector<int>& nums, int k) {
        int n=nums.size(),zero=0,len=0;
        for(int left=0,right=0;right<n;right++)
        {
            if(nums[right]==0) zero++;
            while(zero>k)
                if(nums[left++]==0) zero--;
        }
        return len;

    }
};

四、长度最小的子数组

1、题目讲解

2、讲解算法原理

3、代码实现

cpp 复制代码
class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums)
     {
         int n=nums.size(),len=INT_MAX;
         int sum=0;
         for(int left=0,right=0;right<n;right++)
         {
             sum+=nums[right];
             while(sum>=target)
             {
                 len=min(len,right-left+1);
                 sum-=nums[left];
                 left++;
             }
         }
         return len==INT_MAX?0:len;
     }
};

相关推荐
*TQK*24 分钟前
双指针算法介绍+算法练习(2025)
c++·学习·算法·双指针
陈果然DeepVersion25 分钟前
算法奈我何(二)冒泡排序
算法
掘了26 分钟前
C++ 程序员应该了解的 Linux 命令
linux·c++·后端
郭涤生31 分钟前
并行算法_第十章_《C++并发编程实战》笔记
c++·算法·并发编程
SomeB1oody39 分钟前
【Python机器学习】2.2. 聚类分析算法理论:K均值聚类(KMeans Analysis)、KNN(K近邻分类)、均值漂移聚类(MeanShift)
python·算法·机器学习·聚类·分类算法
Cindy辛蒂1 小时前
C语言:计算并输出三个整数的最大值 并对三个数排序
c语言·数据结构·算法
AI技术控1 小时前
计算机视觉算法实战——驾驶员玩手机检测(主页有源码)
算法·计算机视觉·智能手机
newki1 小时前
学习笔记,C/C++编译相关概念与相关示例
android·c++·c
小竹子141 小时前
L2-4 吉利矩阵
算法·矩阵·深度优先
AndrewHZ1 小时前
DeepSeek模型本地化部署方案及Python实现
人工智能·深度学习·算法·语言模型·ai助理·deepseek·本地化部署