代码随想录算法训练营第二天 | 题目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哥那里看一下具体滑动的过程,链接在上面

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

欢迎大家指出我的问题😊

欢迎大家指出我的问题😊

欢迎大家指出我的问题😊

相关文章
|
13天前
|
算法
分享一些提高二叉树遍历算法效率的代码示例
这只是简单的示例代码,实际应用中可能还需要根据具体需求进行更多的优化和处理。你可以根据自己的需求对代码进行修改和扩展。
|
16天前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
24天前
|
算法 测试技术 开发者
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗;代码审查通过检查源代码发现潜在问题,提高代码质量和团队协作效率。本文介绍了一些实用的技巧和工具,帮助开发者提升开发效率。
26 3
|
23天前
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
29天前
|
缓存 分布式计算 监控
优化算法和代码需要注意什么
【10月更文挑战第20天】优化算法和代码需要注意什么
18 0
|
2月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
3月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
57 6
|
3月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
116 2
|
24天前
|
机器学习/深度学习 人工智能 自然语言处理
280页PDF,全方位评估OpenAI o1,Leetcode刷题准确率竟这么高
【10月更文挑战第24天】近年来,OpenAI的o1模型在大型语言模型(LLMs)中脱颖而出,展现出卓越的推理能力和知识整合能力。基于Transformer架构,o1模型采用了链式思维和强化学习等先进技术,显著提升了其在编程竞赛、医学影像报告生成、数学问题解决、自然语言推理和芯片设计等领域的表现。本文将全面评估o1模型的性能及其对AI研究和应用的潜在影响。
19 1
|
2月前
|
数据采集 负载均衡 安全
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
本文提供了多个多线程编程问题的解决方案,包括设计有限阻塞队列、多线程网页爬虫、红绿灯路口等,每个问题都给出了至少一种实现方法,涵盖了互斥锁、条件变量、信号量等线程同步机制的使用。
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
下一篇
无影云桌面