209. 长度最小的子数组 C#实现

  1. 长度最小的子数组

给定一个含有 n个正整数的数组和一个正整数 target

找出该数组中满足其总和大于等于target的长度最小的

子数组

[numsl, numsl+1, ..., numsr-1, numsr] ,并返回其长度**。** 如果不存在符合条件的子数组,返回 0

示例 1:

输入:target = 7, nums = [2,3,1,2,4,3]
输出:2
解释:子数组 [4,3] 是该条件下的长度最小的子数组。

示例 2:

复制代码
输入:target = 4, nums = [1,4,4]
输出:1

示例 3:

复制代码
输入:target = 11, nums = [1,1,1,1,1,1,1,1]
输出:0

提示:

  • 1 <= target <= 109
  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 105

进阶:

  • 如果你已经实现O(n) 时间复杂度的解法, 请尝试设计一个 O(n log(n)) 时间复杂度的解法。

    public class Solution {
    public int MinSubArrayLen(int target, int[] nums) {
    int left = 0, sum = 0, minLength = int.MaxValue;

          for (int right = 0; right < nums.Length; right++)
          {
              sum += nums[right];
    
              // 当当前和大于等于目标时,收缩窗口
              while (sum >= target)
              {
                  minLength = Math.Min(minLength, right - left + 1);
                  sum -= nums[left];
                  left++;
              }
          }
    
          return minLength == int.MaxValue ? 0 : minLength;
      }
    

    }

相关推荐
程序猿看视界34 分钟前
「读书计划」《啊哈!算法》7日结构化学习规划
数据结构·编程·算法竞赛·学习计划·算法学习
夏末秋也凉1 小时前
力扣-动态规划-70 爬楼梯
算法·leetcode·动态规划
dokii11 小时前
待完成leetcode347 前k个高频元素 优先队列
数据结构
大萌神Nagato1 小时前
蓝桥杯15届JavaB组6题
算法·蓝桥杯·深度优先
graceyun1 小时前
初阶数据结构(C语言实现)——3顺序表和链表(1)
c语言·数据结构·链表
2501_902556231 小时前
C++ 中 cin 和 cout 教程
数据结构·c++
Swift社区2 小时前
【Swift 算法实战】利用 KMP 算法高效求解最短回文串
vue.js·算法·leetcode
萌の鱼2 小时前
leetcode 73. 矩阵置零
数据结构·c++·算法·leetcode·矩阵
好看资源平台2 小时前
‌KNN算法优化实战分享——基于空间数据结构的工业级实战指南
数据结构·算法
AllYoung_3622 小时前
WebUI 部署 Ollama 可视化对话界面
人工智能·深度学习·算法·语言模型·aigc·llama