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

莆田建站服务珠宝 网站欣赏

莆田建站服务,珠宝 网站欣赏,怎么查询企业信息,装饰装修工程第一题#xff1a;长度最小的子数组 力扣#xff08;LeetCode#xff09;官网 - 全球极客挚爱的技术成长平台 思路#xff1a; 第一想法肯定时暴力枚举#xff0c;枚举数组任何一个元素#xff0c;把他当起始位置#xff0c;然后从起始位置找最短区间#xff0c;使得…第一题长度最小的子数组 力扣LeetCode官网 - 全球极客挚爱的技术成长平台 思路 第一想法肯定时暴力枚举枚举数组任何一个元素把他当起始位置然后从起始位置找最短区间使得区间和大于等于目标值 利用两个嵌套for循环如果符合条件就记录然后更新结果返回 class Solution { public:int minSubArrayLen(int target, vectorint 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;} }; 由于都是正数因此只要找到最短区间就不必往下继续查找因为可能所有的数都不满足条件因此这里可能返回0并且保证所有数都可更新初始化ret为INT_MAX; 法二滑动窗口 先将右端元素划入窗口然后统计窗口元素和如果大于target更新并且把左端元素滑出继续同时判断是否满足更新结果因为滑出去之和依旧可能满足条件如果窗口不满足right进入下一个窗口。 class Solution { public:int minSubArrayLen(int target, vectorint nums) {int nnums.size(),sum0,lenINT_MAX;for(int left0,right0;rightn;right){sumnums[right];while(sumtarget){lenmin(len,right-left1);sum-nums[left];}}return lenINT_MAX?0:len;} }; 来自一个力扣大佬的形象解释左右指针中间窗口的sum为两指针的“共同财产”就是右指针一直在努力工作挣钱好不容易共同财产大过target记录一下两指针之间的距离结果左指针就开始得瑟挥霍不停花钱往右移动结果花钱一直花到sum又小过target此时右指针不得不再次出来工作不停向右移动周而复始最后取左右指针离得最近的时候 第二题⽆重复字符的最⻓⼦串medium 力扣LeetCode官网 - 全球极客挚爱的技术成长平台 法一依旧是暴力 即先固定一个然后遍历所有创建个哈希表用来记录出现的次数如果大于一则说明出现重复那么就跳出当前循环进入下一个固定的数进行遍历否则就记录此刻长度 class Solution { public:int lengthOfLongestSubstring(string s) {int ret 0; // 记录结果int n s.length();// 1. 枚举从不同位置开始的最⻓重复⼦串// 枚举起始位置for (int i 0; i n; i){// 创建⼀个哈希表统计频次int hash[128] { 0 };// 寻找结束为⽌for (int j i; j n; j){hash[s[j]]; // 统计字符出现的频次if (hash[s[j]] 1) // 如果出现重复的break;// 如果没有重复就更新 retret max(ret, j - i 1);}}// 2. 返回结果return ret;} }; 法二 例题中的 abcabcbb进入这个队列窗口为 abc 满足题目要求当再进入 a队列变成了 abca这时候不满足要求。所以我们要移动这个队列如何移动我们只要把队列的左边的元素移出就行了直到满足题目要求一直维持这样的队列找出队列出现最长的长度时候求出解 步骤就是右端ch元素进入时用哈希表统计次数如果超过1则有重复那么从左侧滑出窗口直到ch次数变为1然后更新。 如果没有超过1说明没有重复直接更新 class Solution { public:int lengthOfLongestSubstring(string s){int hash[128]{0};int left0,right0,ns.size();int ret0;while(rightn){hash[s[right]];while(hash[s[right]]1)//判断进入{hash[s[left]]--;//出窗口然后左边移动}ret max(ret,right-left1);right;//}return ret;} }; 第三题最大连续1的个数 力扣LeetCode官网 - 全球极客挚爱的技术成长平台 思路这题 不要去想怎么翻转不要把问题想的很复杂这道题的结果⽆⾮就是⼀段连续的 1 中间塞了 k 个 0 嘛。因此我们可以把问题转化成求数组中⼀段最⻓的连续区间要求这段区间内 0 的个数不超 过 k 个。 因此先初始化一些变量然后right小于数组大小就一直循环先进入窗口然后统计检查0是否超标不超标就计数超标就依次把左侧元素滑出窗口直到0个数正常然后right处理下一个。 class Solution { public:int longestOnes(vectorint nums, int k){int ret 0;for (int left 0, right 0, zero 0; right nums.size(); right){if (nums[right] 0) zero; // 进窗⼝while (zero k) // 判断if (nums[left] 0) zero--; // 出窗⼝ret max(ret, right - left 1); // 更新结果}return ret;} }
http://www.lakalapos1.cn/news/52832/

相关文章:

  • 重庆网站排名公司上海公关策划有限公司
  • html5做的网站南京中企动力有限公司
  • 网站没收录可以做排名网站设计杭州
  • 网站建设公司推广龙岗互联网公司
  • 成都网站建设服务商商务网站设计实训报告
  • 怎么做简单的网站首页除了小红书还有什么推广平台
  • 怎么上传网站地图莆田企业自助建站系统
  • 如果快速做网站网站都需要什么类别
  • 聊城做网站优化wordpress图片清理
  • 站长之家特效网站如何搭建个人网站
  • 做代练的网站优化网站排名怎么制作
  • 如何查询网站打开速度变慢上海建筑设计院院长
  • 工业和信息网站备案管理系统做网站用什么语言简单
  • 濮阳市建设分局网站网络维护人员
  • 做网站费用分摊入什么科目企业营销平台
  • 网站建设的主要功能有哪些深圳学校网站建设报价
  • 手机直接看的网站有哪些现在什么行业发展前景最好
  • iis不用dns解析还有什么办法也能一个ip对应多个网站吗网站负责人 主体负责人
  • 湖南省长沙建设工程造价站网站h5成品网站
  • 商务酒店设计网站建设网络营销的特点哪四个
  • wordpress排行榜时空seo助手
  • 商业网站源码免费下载wordpress更改logo
  • 网站提交百度收录申请一个电子邮箱号
  • 做配资网站多少钱免费psd图片素材网站
  • 做八年级题目的网站浏览器正能量网站免费软件
  • 申报教学成果奖的网站建设百度如何创建网站
  • 凡科网做网站花多少钱wordpress右下角设置
  • 西安哪里有做网站的吉林省建设厅安全证查询网站
  • 肇庆建设网站凡科如何开通网站建设
  • 推荐邯郸网站建设建网站需多少钱