0
点赞
收藏
分享

微信扫一扫

209. 长度最小的子数组(Leetcode刷题笔记)

王老师说 2022-02-04 阅读 40

209. 长度最小的子数组(Leetcode刷题笔记)

https://lunan0320.cn

文章目录

题目

给定一个含有 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

解题代码 C++(核心)

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int res = INT_MAX;    //最小窗口
        int sublength = 0; //滑动窗口长度
        int sums = 0;   //窗口内的数值之和
        int begin = 0;  //窗口起始点
        int length = nums.size();
        for(int end = 0; end < length; end++){
            //依次遍历每一个值
            sums += nums[end];
            //起始位置的循环前移
            while(sums >= target){
                sublength = end - begin + 1;
                res = res < sublength ? res : sublength;
                sums -= nums[begin++];
            }
        }
        return res == INT_MAX ? 0 : res;
    }
};

解题代码 C++(本地编译运行)

//head.h
#pragma once
#include <iostream>
#include <vector>
#include <string>

using namespace std;

// Solution.h
//滑动窗口
class Solution4 {
public:
	int minSubArrayLen(int target, vector<int>& nums) {
		int res = INT_MAX;//最小窗口大小
		int subLength = 0; //当前窗口大小
		int begin = 0; //窗口起始
		int sum = 0;
		for (int end = 0; end < nums.size(); end++) {
			//遍历
			sum += nums[end];
			while (sum >= target) {
				subLength = end - begin + 1;
				res = res < subLength ? res : subLength;
				//窗口前移关键
				sum -= nums[begin++];
			}
		}
		return res;
	}
};
//main.cpp
#include "Solution2.h"
int main() {
	Solution4 solution;
	vector<int> nums = { 2,3,1,2,4,3 };
	int target = 7;
	cout << solution.minSubArrayLen(target, nums) << endl;

}

算法效率

举报

相关推荐

0 条评论