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

网站全屏大图代码互联网舆情

网站全屏大图代码,互联网舆情,信息化建设 网站,怎样做一个自己的网站滑动窗口本质其实也是一种双指针算法#xff0c;只是因为它维护的区间随着遍历的进行在不停变化#xff0c;所以形象地称为“滑动窗口” 一、⻓度最⼩的⼦数组 题目要求找到满足条件的长度最小的子数组#xff0c;我们先来想想暴力的做法#xff0c;再来想想能不能优化只是因为它维护的区间随着遍历的进行在不停变化所以形象地称为“滑动窗口” 一、⻓度最⼩的⼦数组 题目要求找到满足条件的长度最小的子数组我们先来想想暴力的做法再来想想能不能优化一般来说这种找子数组的暴力就是两层for循环枚举左右两个端点找到符合条件的所有子数组然后找出最小值下面画个图给大家分析一下 代码如下 class Solution { public:int minSubArrayLen(int target, vectorint nums) {int ansnums.size()1;for(int left0,right0,s0;rightnums.size();right){//进窗口snums[right];//判断是否需要出窗口while(starget){//更新答案ansmin(ans,right-left1);s-nums[left];}}return ansnums.size()1?0:ans;} }; 通过这道题我们就能总结出一些规律滑动窗口的题目分为三个步骤进窗口判断是否出窗口以及何时更新答案当然前提是你得先判断出这题是用滑动窗口解 二、将x减到0的最⼩操作数 这题如果你开始模拟左右两个区间之和x而没有想过转化条件那它就会很难解决但是其实题目可以等价成找元素和sum(nums)-x的最长子数组的长度最后用数组长度减去最长子数组长度就能得到最小操作数而等价后的题目明显和上一道题几乎一样这里就不具体分析了 代码如下 class Solution { public:int minOperations(vectorint nums, int x) {int nnums.size();int targetaccumulate(nums.begin(), nums.end(), 0)-x;if(target0) return -1;//注意判断边界条件int ansn1;for(int left0,right0,s0;rightnums.size();right){//进窗口snums[right];//判断是否出窗口while(starget) s-nums[left];//更新答案if(starget) ansmin(ans,n-(right-left1));}return ansn1?-1:ans;} }; 好经过上面的题目我们就已经对滑动窗口的题目更多的认识和了解关键在于发现题目可以用滑动窗口解决以及维护区间的某些属性同时两个指针往同一方向移动(即满足某种单调性)---滑动窗口的特征 三、⽔果成篮   这道题目就是维护区间内水果类型是否大于2思路如下 进窗口-判断是否出窗口-更新答案 的细节在下面的代码里(请细品) class Solution { public:int totalFruit(vectorint fruits) {int nfruits.size(),ans0;int cnt[n];memset(cnt,0,sizeof(cnt));for(int left0,right0,s0;rightn;right){//进窗口if(cnt[fruits[right]]1)//出现次数为1次说明水果种类增加s1;//判断是否出窗口while(s2){if(--cnt[fruits[left]]0)//出现次数为0次说明水果种类减少s-1;}ansmax(ans,right-left1);}return ans;} }; 四、找到字符串中所有字⺟异位词 这题跟上面几题不太一样这题的窗口长度是固定的就是查看字符串s中p.size()的窗口有几个是和组成p的字符一样记录下标步骤还是 进窗口-判断是否出窗口-更新答案  代码如下 class Solution { public:vectorint findAnagrams(string s, string p) {vectorintans;int hash1[26]{0},hash2[26]{0},kp.size(),cout0;for(int i0;ip.size();i)hash1[p[i]-a];for(int left0,right0;rights.size();right){//进窗口char ins[right];//如果加完之后该字符的数量任然p中该字符的数量说明增加的是有效字符coutif(hash2[in-a]hash1[in-a]) cout;//出窗口if(right-left1k){char outs[left];//如果该字符的个数本就p中该字符的数量说明减少的是有效字符cout--if(hash2[out-a]--hash1[out-a])cout--;}//更新答案if(kcout) ans.push_back(left);}return ans;} }; 总结牢记滑动窗口的三个步骤进窗口判断是否出窗口以及何时更新答案稍难的滑动窗口一般都是和哈希表结合起来主要是在判断进窗口和出窗口的条件上下文章当然一切的前提是你能想到用滑动窗口来解决问题当问题和维护一段连续区间的属性有关时我们就可以想一想滑动窗口
http://www.w-s-a.com/news/15783/

相关文章:

  • 怎么做一个免费的网站云南网站设计选哪家
  • dw做六个页面的网站做网站运营有前途吗
  • 中级网站开发工程师 试题战地之王网站做任务
  • 广东东莞保安公司湖南 seo
  • 无锡网站策划公司如何零基础学编程
  • 金融网站如何做设计网站开发流程 文档
  • 用jsp做网站国内知名设计工作室
  • 一键搭建网站北京公司网站设计
  • 山东省城乡建设部网站网站营销单页怎么做
  • 中国移动视频网站建设百度统计官网
  • 网站实施过程网站上传视频怎么做
  • 网上书店网站建设实训总结嘉兴seo
  • 网站运行需求cos wordpress
  • 网络小说网站推广策划方案单位网站建设收费标准
  • 医院网站建设论证报告河源网站seo
  • 网站demo怎么做淘宝客网站一般用什么做的
  • 网站开发之美 pdf关键词查询优化
  • 可以建站的网站做一个网站美工多少钱
  • 怎么做网站专题互联网营销师报考费用
  • 淘宝导购网站怎么做上海数据开放网站建设
  • 广东网站建设怎么选2021个人网站盈利模式
  • 珠海网站建设的公司排名网站前端开发培训
  • 手机网站制作 费怎么做分录网站域名hk
  • 济南做网站建网站公司怎样用代码制作网站
  • 网站开发文档有哪些建设规划
  • 专注网站建设11年百度搜索不到我的网站
  • 企业网站 建设 流程wordpress 分类目录自定义
  • 北京市建设管理公司网站长春网站推广排名
  • 西安建站软件获取网站全站代码
  • 个人做网站怎么备案网站建设收费标准渠道