代码随想录算法训练营第二天 | 题目2(LeetCode209.长度最小的子数组)

简介: LeetCode209.长度最小的子数组

这道题利用了滑动窗口,所以来记录一下

欢迎大家指出我的问题😊

欢迎大家指出我的问题😊

欢迎大家指出我的问题😊

原题链接:209. 长度最小的子数组 - 力扣(LeetCode)

这是Carl哥的分享:代码随想录 (programmercarl.com)

题目图片3.1.png

🍔这里就不写暴力解法了

看   滑动窗口

其实也是定义了两个指针

时间复杂度:O(n)

空间复杂度:O(1)

下面的图片是Carl哥的😂 3.2.png

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int sum=0,result=INT32_MAX,j=0,len=0;
        for(int i=0;i<nums.size();i++)
        {
            sum+=nums[i];
            while(sum>=target)
            {
                len=i-j+1;
                result=result<len?result:len;
                sum-=nums[j++];
            }
        }
        return result==INT32_MAX?0:result;//尝试这种写法
    }
};

下面解释一下代码里面的INT32_MAX是什么意思3.3.png

不能够直接使用-2147483648来代替最小负数,因为这不是一个数字,而是一个表达式。


意思是对整数21473648取负,但是2147483648已经溢出了int的上限,所以定义为 -INT32_MAX-1


🚥🚥🚥🚥🚥🚥


外加一道题


904. 水果成篮 - 力扣(LeetCode)

3.4.png

class Solution {
public:
    int totalFruit(vector<int>& fruits) {
        int l=0,r=0,res=0,cnt=0;
        vector<int>v(fruits.size()+1,0);
        while(r<fruits.size())
    {
            if(v[fruits[r]]==0)
            {
              cnt++;
      }   
            v[fruits[r]]++;  
            while(cnt>2)
      {
                v[fruits[l]]--;
                if(v[fruits[l]]==0)//每少一个cnt,l就向前移一位
                {          //因为不能加上0,加上等于白加
                  cnt--;
        }    
                l++;              //l必须要在后面      
            }
            res=max(res,r-l+1);
            r++;//窗口前移   r=0---fruits[0] 
          //         r=1---fruits[1]
        //           r=2---fruits[2]         
        }
        return res;
    }
};

如果看不懂代码,可以去Carl哥那里看一下具体滑动的过程,链接在上面

🏳️‍🌈🏳️‍🌈🏳️‍🌈🏳️‍🌈🏳️‍🌈🏳️‍🌈

欢迎大家指出我的问题😊

欢迎大家指出我的问题😊

欢迎大家指出我的问题😊

相关文章
|
1天前
|
算法 测试技术 开发者
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗;代码审查通过检查源代码发现潜在问题,提高代码质量和团队协作效率。本文介绍了一些实用的技巧和工具,帮助开发者提升开发效率。
6 3
|
13天前
|
存储 缓存 算法
如何通过优化算法和代码结构来提升易语言程序的执行效率?
如何通过优化算法和代码结构来提升易语言程序的执行效率?
|
14天前
|
搜索推荐
插入排序算法的讲解和代码
【10月更文挑战第12天】插入排序是一种基础的排序算法,理解和掌握它对于学习其他排序算法以及数据结构都具有重要意义。你可以通过实际操作和分析,进一步深入了解插入排序的特点和应用场景,以便在实际编程中更好地运用它。
|
6天前
|
缓存 分布式计算 监控
优化算法和代码需要注意什么
【10月更文挑战第20天】优化算法和代码需要注意什么
13 0
|
7天前
|
算法 安全 数据安全/隐私保护
基于game-based算法的动态频谱访问matlab仿真
本算法展示了在认知无线电网络中,通过游戏理论优化动态频谱访问,提高频谱利用率和物理层安全性。程序运行效果包括负载因子、传输功率、信噪比对用户效用和保密率的影响分析。软件版本:Matlab 2022a。完整代码包含详细中文注释和操作视频。
|
26天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于MSER和HOG特征提取的SVM交通标志检测和识别算法matlab仿真
### 算法简介 1. **算法运行效果图预览**:展示算法效果,完整程序运行后无水印。 2. **算法运行软件版本**:Matlab 2017b。 3. **部分核心程序**:完整版代码包含中文注释及操作步骤视频。 4. **算法理论概述**: - **MSER**:用于检测显著区域,提取图像中稳定区域,适用于光照变化下的交通标志检测。 - **HOG特征提取**:通过计算图像小区域的梯度直方图捕捉局部纹理信息,用于物体检测。 - **SVM**:寻找最大化间隔的超平面以分类样本。 整个算法流程图见下图。
|
4天前
|
人工智能 算法 数据安全/隐私保护
基于遗传优化的SVD水印嵌入提取算法matlab仿真
该算法基于遗传优化的SVD水印嵌入与提取技术,通过遗传算法优化水印嵌入参数,提高水印的鲁棒性和隐蔽性。在MATLAB2022a环境下测试,展示了优化前后的性能对比及不同干扰下的水印提取效果。核心程序实现了SVD分解、遗传算法流程及其参数优化,有效提升了水印技术的应用价值。
|
6天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于贝叶斯优化CNN-LSTM网络的数据分类识别算法matlab仿真
本项目展示了基于贝叶斯优化(BO)的CNN-LSTM网络在数据分类中的应用。通过MATLAB 2022a实现,优化前后效果对比明显。核心代码附带中文注释和操作视频,涵盖BO、CNN、LSTM理论,特别是BO优化CNN-LSTM网络的batchsize和学习率,显著提升模型性能。
|
10天前
|
存储
基于遗传算法的智能天线最佳阵列因子计算matlab仿真
本课题探讨基于遗传算法优化智能天线阵列因子,以提升无线通信系统性能,包括信号质量、干扰抑制及定位精度。通过MATLAB2022a实现的核心程序,展示了遗传算法在寻找最优阵列因子上的应用,显著改善了天线接收功率。
|
12天前
|
监控 算法 数据安全/隐私保护
基于三帧差算法的运动目标检测系统FPGA实现,包含testbench和MATLAB辅助验证程序
本项目展示了基于FPGA与MATLAB实现的三帧差算法运动目标检测。使用Vivado 2019.2和MATLAB 2022a开发环境,通过对比连续三帧图像的像素值变化,有效识别运动区域。项目包括完整无水印的运行效果预览、详细中文注释的代码及操作步骤视频,适合学习和研究。