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

如何免费做网站并发布微站是什么东西

如何免费做网站并发布,微站是什么东西,公司页面设计代码,网站建设具体流程目录 1.题目 1.解法⼀(暴⼒求解)(会超时): 2.解法⼆(滑动窗⼝): 1.算法思路: 2.手撕图解 3.代码实现 1.C 2.C语言 1.题目 209. 长度最小的子数组 给定一个含有 n…

目录

 1.题目

1.解法⼀(暴⼒求解)(会超时):

 2.解法⼆(滑动窗⼝):

1.算法思路:

2.手撕图解

3.代码实现

 1.C++

2.C语言 


 1.题目

209. 长度最小的子数组

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

1.解法⼀(暴⼒求解)(会超时):


算法思路:
「从前往后」枚举数组中的任意⼀个元素,把它当成起始位置。然后从这个「起始位置」开始,然
后寻找⼀段最短的区间,使得这段区间的和「⼤于等于」⽬标值。
将所有元素作为起始位置所得的结果中,找到「最⼩值」即可。

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {// 记录结果int ret = INT_MAX;int n = nums.size();// 枚举出所有满⾜和⼤于等于 target 的⼦数组[start, end]// 由于是取到最⼩,因此枚举的过程中要尽量让数组的⻓度最⼩// 枚举开始位置for (int start = 0; start < n; start++) {int sum = 0; // 记录从这个位置开始的连续数组的和// 寻找结束位置for (int end = start; end < n; end++) {sum += nums[end];  // 将当前位置加上if (sum >= target) // 当这段区间内的和满⾜条件时{// 更新结果,start 开头的最短区间已经找到ret = min(ret, end - start + 1);break;}}}// 返回最后结果return ret == INT_MAX ? 0 : ret;}
};

 2.解法⼆(滑动窗⼝):


1.算法思路:


由于此问题分析的对象是「⼀段连续的区间」,因此可以考虑「滑动窗⼝」的思想来解决这道题。
让滑动窗⼝满⾜:从 i 位置开始,窗⼝内所有元素的和⼩于target(那么当窗⼝内元素之和
第⼀次⼤于等于⽬标值的时候,就是 i 位置开始,满⾜条件的最⼩⻓度)。


做法:将右端元素划⼊窗⼝中,统计出此时窗⼝内元素的和:


▪ 如果窗⼝内元素之和⼤于等于 target :更新结果,并且将左端元素划出去的同时继续判
断是否满⾜条件并更新结果(因为左端元素可能很⼩,划出去之后依旧满⾜条件)


▪ 如果窗⼝内元素之和不满⾜条件: right++ ,另下⼀个元素进⼊窗⼝。


相信科学(这也是很多题解以及帖⼦没告诉你的事情:只给你说怎么做,没给你解释为什么这么
做):

为何滑动窗⼝可以解决问题,并且时间复杂度更低


▪ 这个窗⼝寻找的是:以当前窗⼝最左侧元素(记为 left1 )为基准,符合条件的情况。也
就是在这道题中,从 left1 开始,满⾜区间和 sum >= target 时的最右侧(记为right1 )能到哪⾥。


▪ 我们既然已经找到从 left1 开始的最优的区间,那么就可以⼤胆舍去 left1 。但是如
果继续像⽅法⼀⼀样,重新开始统计第⼆个元素( left2 )往后的和,势必会有⼤量重复
的计算(因为我们在求第⼀段区间的时候,已经算出很多元素的和了,这些和是可以在计算
下次区间和的时候⽤上的)。
▪ 此时, rigth1 的作⽤就体现出来了,我们只需将 left1 这个值从 sum 中剔除。从right1 这个元素开始,往后找满⾜eft2 元素的区间(此时right1也有可能是满⾜的,因为 left1 可能很⼩。 sum 剔除掉left1 之后,依旧满⾜⼤于等于target )。这样我们就能省掉⼤量重复的计算。
▪ 这样我们不仅能解决问题,⽽且效率也会⼤⼤提升。
时间复杂度:虽然代码是两层循环,但是我们的 left 指针和right 指针都是不回退的,两者
最多都往后移动 n 次。因此时间复杂度是O(N)

2.手撕图解

3.代码实现

INT_MAX是C语言中的一个宏定义,表示整型数据类型int的最大值。在32位系统中,它的值为2147483647;在64位系统中,它的值为9223372036854775807。这个值可以用来进行数据类型转换、判断数据是否越界等操作。

 1.C++

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int n = nums.size(), sum = 0, len = INT_MAX;for (int left = 0, right = 0; right < n; right++) {sum += nums[right];   // 进窗⼝while (sum >= target) // 判断{len = min(len, right - left + 1); // 更新结果sum -= nums[left++];              // 出窗⼝}}return len == INT_MAX ? 0 : len;}
};

2.C语言 

int minSubArrayLen(int target, int* nums, int numsSize)
{int sum = 0, len = INT_MAX;for (int left = 0, right = 0; right < numsSize; right++) {sum += nums[right];   // 进窗⼝while (sum >= target) // 判断{len = len < right - left + 1 ? len : right - left + 1; // 更新结果sum -= nums[left++];              // 出窗⼝}}return len == INT_MAX ? 0 : len;
}

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

相关文章:

  • 互联网网站 有哪些株洲网站建设技术公司
  • 网站规划建设与管理维护教学大纲东莞展厅设计公司
  • 网站软文推广好处wordpress全站ajax
  • 西部数码网站备案查询app应用网站html5模板下载
  • 推广做网站电商o2o是什么意思
  • 石家庄城乡建设局网站6为什么我的网站百度不收录
  • 专业的网站设计建设青岛网站建设多少钱
  • 做外贸的人经常用什么网站wordpress 响应式模版
  • 泉州网站排名网站开发实验报告总结
  • h5 响应式手机网站做网站流程视频
  • 利用淘宝联盟做网站手机下载微信电脑版官方免费下载
  • 外链博客网站华强电子网官网
  • 外贸出口平台网站软文营销的方法
  • 海南网站建设海南网络公司专业建站开发
  • 国内做网站哪个好优秀网站模板欣赏
  • 制作一个收费网站要多少钱网络营销的主要工作有哪些
  • 网站建设合同内容wordpress xml插件下载
  • 南京栖霞区有做网站的吗域名建网站
  • 淄博网站公司电话乐清虹桥门户网
  • 怎样建设商城网站辽宁双高建设专题网站
  • 口碑好的网站建设公司哪家好win10做网站服务器
  • 如果网站打开非常缓慢如何制作自己的网站和app
  • aspcms 生成网站地图百度搜题
  • 网站定制开发一般多久南京做网站制作公司
  • 万江网站建设全国公示信息查询平台
  • 企业网站建设 推广我想在购物网站做代理
  • 学校网站在建设方面的的优势网站底部设计源码
  • 厦门网站建设公司排行榜做海淘的网站
  • 查公司的口碑和评价的网站购买链接平台
  • 鞍山 中企动力提供网站建设3d动画制作