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

百度网站地图在线生成免费b站推广网站下载

百度网站地图在线生成,免费b站推广网站下载,WordPress无缩略图文章筛选,网站wap版🌟快来参与讨论💬,点赞👍、收藏⭐、分享📤,共创活力社区。 🌟 别再犹豫了!快来订阅我们的算法每日双题精讲专栏,一起踏上算法学习的精彩之旅吧!💪…

🌟快来参与讨论💬,点赞👍、收藏⭐、分享📤,共创活力社区。 🌟

别再犹豫了!快来订阅我们的算法每日双题精讲专栏,一起踏上算法学习的精彩之旅吧!💪

今天,咱们就一同来探究 “水果成篮” 和 “找到字符串中所有字母异位词” 这两道经典题目,看看滑动窗口算法是如何在其中施展魔法的🧙‍♂️。


目录

💯水果成篮

📖题目描述

🧠讲解算法原理

💻代码实现(以 C++ 为例)

💯找到字符串中所有字母异位词

📖题目描述

 🧠讲解算法原理

 💻代码实现(以 C++ 为例)


💯水果成篮


题目链接👉【力扣】

📖题目描述

根据示例分析,该题的本质就是:找出最长子数组的长度,子数组不超过俩种水果类型

🧠讲解算法原理

解法一:

 我们用暴力解法写一下,例如f=[1,2,3,2,2]

依次找出所以的情况👇

  1.  

代码中我们利用哈希表列举情况,用哈希表统计水果出现的类型数

解法二:

先分析

 当我们用暴力解法时,遇到如下情况👇,我们让 left++ ,right 回到 left的位置,继续列举情况

当left++时,区间的 kinds 要么不变,要么减少一个

  • 当kinds不变时,right没有必要改变
  • 当kinds减少时,right可以继续向后移动

 因此我们可以用滑动窗口的解法,right不回退嘛

滑动窗口四大步:

  1.  left=0,right=0
  2. 进窗口——right右移动的时候
  3. 判断    出窗口——就是left右移动的时候
  4. 更新结果

举例: f=[1,2,1,2,3,2,3,3]

每次遍历right,让其放入hash表里面,判断有没有超出类型个数

当hash.length>2时出窗口

left右移动的时候,要根据某个水果种类的数量来进行移动,因此我们创建的hash表要有俩个参数,一个记录种类,一个记录个数

例如下面👇,我们要将left移动到3的前面

💻代码实现(以 C++ 为例)

class Solution {
public:int totalFruit(vector<int>& fruits) {int hash[100001]={0};//统计窗口内出现了多少种结果int ret=0;for(int left=0,right=0,kinds=0;right<fruits.size();right++){if(hash[fruits[right]]==0) kinds++;hash[fruits[right]]++;//进窗口while(kinds>2)//判断{//出窗口hash[fruits[left]]--;if(hash[fruits[left]]==0)   kinds--;left++;}ret=max(ret,right-left+1);}return ret;}
};

💯找到字符串中所有字母异位词


题目链接👉【力扣】

📖题目描述

 

 🧠讲解算法原理

1.如何判断俩个字符串是否是异位词?

  • 可以先排序再比较,但是时间复杂度为nlogn ,比较大
  • 通过统计字符串中字符出现的个数也可以判断,借助hash表即可

 2.解决问题

例如

暴力解法: 

计入p的长度m ,在S里依次比较 

 

优化解法:

当字符串依次遍历时, ,我们发现ba重复出现,所以我们只要将c从hash表移除,让e加入hash表即可,滑动窗口

 

滑动窗口四大步:

  1.  left=0,right=0
  2. 进窗口——right右移动的时候
  3. 判断    出窗口——就是left右移动的时候
  4. 更新结果

 

3.优化:更新结果的判断条件

利用变量count来统计窗口中“有效字符”的个数

使用一个数组targetCount来记录字符串p中每个字母的出现次数,再使用一个数组windowCount来记录当前窗口内每个字母的出现次数。设一个变量valid来表示窗口内有效字母的数量,初始值为0。 

然后,将right指针向右移动,每移动一次,就将新字母在windowCount中的计数加1,并检查该字母的计数是否等于在targetCount中的计数,如果相等,则valid1。当valid等于p中不同字母的数量时,说明当前窗口是一个字母异位词。

 

此时,将left指针向右移动,同时更新windowCountvalid,直到valid小于p中不同字母的数量。在移动left指针的过程中,如果窗口内的子串长度等于p的长度,就将left指针的索引加入到结果数组中。

 

重复上述步骤,直到right指针走到字符串s的末尾。最后,返回结果数组。

 💻代码实现(以 C++ 为例)

class Solution {
public:vector<int> findAnagrams(string s, string p) {vector<int> result;// 如果s的长度小于p的长度,直接返回空结果if (s.length() < p.length()) return result;// 用于记录字符串p中每个字母的出现次数vector<int> targetCount(26, 0);// 用于记录当前窗口内每个字母的出现次数vector<int> windowCount(26, 0);int valid = 0;// 初始化targetCount数组for (char c : p) {targetCount[c - 'a']++;}int left = 0, right = 0;while (right < s.length()) {int rightIndex = s[right] - 'a';// 将新字母在windowCount中的计数加1windowCount[rightIndex]++;// 如果该字母的计数小于等于在targetCount中的计数,说明该字母在窗口内的数量还未超过p中该字母的数量,有效字母数量加1if (windowCount[rightIndex] <= targetCount[rightIndex]) {valid++;}// 当窗口大小大于p的长度时,移动left指针缩小窗口while (right - left + 1 > p.length()) {int leftIndex = s[left] - 'a';// 将left指针指向的字母在windowCount中的计数减1windowCount[leftIndex]--;// 如果该字母的计数小于在targetCount中的计数,说明该字母在窗口内的数量已经小于p中该字母的数量,有效字母数量减1if (windowCount[leftIndex] < targetCount[leftIndex]) {valid--;}left++;}// 如果有效字母数量等于p中不同字母的数量,说明当前窗口是一个字母异位词,将left指针的索引加入结果数组if (valid == p.length()) {result.push_back(left);}right++;}return result;}
};

我以后还会对 算法 相关知识进行更多的创作,欢迎大家关注我,一起探索 算法 的奇妙世界😜

👉【A Charmer】

http://www.hkea.cn/news/277092/

相关文章:

  • 做贷款网站优化大师有用吗
  • 有没有便宜的网站制作制作网页教程
  • 医院网站制作优化关键词的方法有哪些
  • wordpress安装到网站吗泰安seo
  • 长春网站开发培训价格google play三件套
  • 做生存分析的网站有哪些国外新闻最新消息
  • 济南网站优化收费百度互联网营销
  • bootstrap响应网站模板下载发帖推广百度首页
  • 动态网站上的查询怎么做新媒体运营培训学校
  • 网站开发人员必备技能百度优化推广
  • 花都 网站建设百度推广怎么添加关键词
  • 开发公司成本部职责岗位职责和流程苏州网站建设优化
  • 湛江网站制作系统seo排名需要多少钱
  • 城乡现代社区建设seo关键词推广案例
  • 旅游网站开发外文文献关键洞察力
  • 大学生asp网站开发的实训周长沙百度快速优化
  • 黑龙江省建设网站百度投流运营
  • 网站关键词太多好不好兰州seo整站优化服务商
  • 义乌网站设计网店推广策划方案
  • 无锡网站优化工作室网站关键词排名优化推广软件
  • 长沙做网站的公司亚马逊seo什么意思
  • 仪征建设银行官方网站怎么优化一个网站
  • 那个网站可以查询美做空基金宁波网站推广平台效果好
  • 杨凌企业网站建设天津seo优化
  • 建设网站的工具免费b站在线观看人数在哪儿
  • 毕业设计餐饮网站建设国内前10电商代运营公司
  • 日本b2b网站市场调研的步骤
  • 强企网做网站网店推广有哪些
  • 博物馆网站建设策划书公司如何在百度宣传
  • 做cpa广告网站教程百度sem推广具体做什么