当前位置: 首页 > news >正文

建设银行企业网站失败wordpress 开发分销

建设银行企业网站失败,wordpress 开发分销,网站免费正能量不用下载,设计网站开发目录 题目描述 题解 思路分析 暴力枚举代码 滑动窗口代码 题目描述 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl1, ..., numsr-1, numsr] ,并返回其长度。如果不存在符合条…

目录

题目描述

题解

思路分析

暴力枚举代码

滑动窗口代码


题目描述

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

找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl+1, ..., numsr-1, numsr] ,并返回其长度如果不存在符合条件的子数组,返回 0 。

示例:

输入:target = 7, nums = [2,3,1,2,4,3]
输出:2
输入:target = 4, nums = [1,4,4]
输出:1

题解

思路分析

题目要求我们找到和 >= target 最小连续 的子数组,我们很容易想到暴力枚举的方法,即访问数组的每一个元素i,并将i作为第一个元素,向后寻找

暴力枚举代码

class Solution {public int minSubArrayLen(int target, int[] nums) {int count = 0;for(int i = 0; i < nums.length; i++){int sum = 0;//向后遍历找到以nums[i]为起始元素的最小数组for(int j = i; j < nums.length;j++){sum += nums[j];if(sum >= target){//更新目标值 由于count的初始值为0,因此需要更新初始值,//否则最小值恒为0if(count > j-i+1 || count == 0){count = j-i+1;}break;}}}//若count未被更新,则返回0,即没有子数组的和大于target,//若count被跟新,则返回最小的子数组长度return count;}
}

 

此时我们通过遍历访问了数组的每个元素,在访问每个元素时,以该元素为起始元素,并向后寻找其最小长度的子数组,因此时间复制度为O(^{_N{2}})

而,题目所给的数组中所有元素均是正整数,因此每加上一个元素,子数组的和 sum 增加,通过这个特性,我们可以想到使用滑动窗口来解决这个问题

什么是滑动窗口?

滑动窗口是一种基于双指针的思想,两个指针指向的元素之间形成了一个窗口

因此滑动窗口是通过两个指针来维护的,那么如何移动这两个指针,是使用滑动窗口解决问题的关键

 初始时,两个指针都指向0下标位置

遍历元素,若条件不满足,则将right指针向右移动,直到条件满足为止

条件满足时,则保持右指针不变,开始移动左指针 left

在向窗口中添加新元素或从窗口中删除旧元素时,可能会更新一些与窗口范围有关的数据(例如,本题就需要更新最小子数组的长度)

如何使用滑动窗口解决本题? 

(1)我们定义两个指针left right,并让其都指向数组首元素

 

(2)此时窗口内只有 2 这一个元素,不满足和 sum >= target,因此将right向右移动,将新的元素加入窗口中,并判断此时子数组的和 sum 是否大于等于target,若满足,则不再移动right

(3)在sum >= target时,首先判断最小的子数组长度是否需要更新,并保持right不变,向右移动左指针left,删除旧的元素,直到sum < target

(4)循环(2)(3),直到right遍历完数组

为什么可以使用滑动窗口解决本题?
 

因为我们要找的子数组是连续的,且数组中的元素都为正整数,即子数组中增加一个元素,子数组中的元素和sum增加,从窗口中删除一个元素,sum减小,因此我们可以通过改变子数组的两端元素来更新数组,因此可以使用滑动窗口来解决本题

由于左右指针都只遍历了一遍数组,因此时间复杂度O(N)

滑动窗口代码

class Solution {public int minSubArrayLen(int target, int[] nums) {int left = 0;int right = 0;int sum = nums[0];int len = nums.length;int count = 0;while(left <= right && right < len){//小于目标值,向右移动右指针rightwhile(left <= right && right < len && sum < target){right++;if(right == len){break;}sum += nums[right];}//大于等于目标值while(left <= right && sum >= target){//更新目标值 由于count的初始值为0,因此需要更新初始值,否则最小值恒为0if((right - left) < count || count == 0){count = right - left + 1;}//左边值出窗口,left向右移动sum -= nums[left];left++;}}//若count未被更新,则返回0,即没有子数组的和大于target,//若count被跟新,则返回最小的子数组长度return count;}
}

题目来自:

LCR 008. 长度最小的子数组 - 力扣(LeetCode)

http://www.yayakq.cn/news/324435/

相关文章:

  • 广东网站建设建站模板网站未备案的后果
  • wordpress简约下载站模板下载c 做网站教程
  • 临夏网站建设asp 公司网站
  • 佛山响应式网站设计西安vi设计公司
  • 自做网站打开速度慢空壳网站查询
  • 湖北省住房和城乡建设厅官方网站佛山市和城乡建设局网站首页
  • 爱搜索中级网站建设国外的云服务器租用
  • 黄页网站怎么查毕业网站设计
  • 网站开发与技术分析网站建设面谈话术
  • 移动网站建站视频雅虎做网站推广
  • 怎样做商业网站平台科技公司做网站
  • 自己做电影网站违法吗织梦做网站的详情
  • asp 网站名字装修公司哪家好广州市
  • 快站app官网下载如何查看网站备案信息
  • 山东建设厅官方网站李兴军怎么自建一个网站
  • 成都食品网站开发检测网站建设
  • 男女做暖暖暖网站知名做网站的公司
  • 电商型网站android开发环境搭建
  • 云南技术网站建设销售延安微网站建设
  • 邮件验证登录网站开发山东世界500强企业
  • 成都高端网站设计公司常用的网站类型有哪些
  • 带注册的网站需要多大空间免费美食网站源码
  • 网站内容的建设建设工程 质量 协会网站
  • 北京中国建设工程造价管理协会网站太仓seo网站优化软件
  • 上海网站建设 网页制作免费ppt模板大全网址
  • 在阿里云里网站建设的步骤过程室内设计效果图招聘
  • 一键做网站wordpress主题demo导入
  • 网站建设对用户影响网站设置点赞
  • 贵港北京网站建设网络广告推广服务
  • 天津企商网站建设公司设计方案范本