25.1.10学习笔记(算法(滑动窗口))

题目:在leetcode上

解释:什么是滑动窗口呢,在这道题里面,子串的长度为k,所以我们就可以将这个子串看为一个窗口,每次去统计窗口里面有多少满足要求,然后进行相关值的加减,滑动就体现在子串的第一个元素离开窗口,紧接着本来在窗口后的元素进入窗口,这样的步骤就像是窗口向后滑动了一样。

优点:这样相比较暴力求解,大大减小了运算量,复杂度为o(n),相对于暴力的o(nk)少了很多。

下面是按照这个算法写的代码

#define MAX(a,b) (a)>(b)?(a):(b)

int maxVowels(char* s, int k) {

int ans=0,vowel=0;

for(int i=0;s[i];i++){

//1.进入窗口

if(s[i]=='a'||s[i]=='e'||s[i]=='i'||s[i]=='o'||s[i]=='u'){

vowel++;

}

if(i<k-1){

continue;

}

//2.更新答案

ans=MAX(ans,vowel);

//3.离开窗口

char out=s[i-k+1];

if(out=='a'||out=='e'||out=='i'||out=='o'||out=='u')

{

vowel--;

}

}

return ans;

}

相关推荐
网络安全成叔1 小时前
【入门级】计算机网络学习
学习·计算机网络·web安全·计算机·网络安全·编程
梳子烟YAN2 小时前
UML系列之Rational Rose笔记一:用例图
笔记·uml
不是只有你能在乱世中成为大家的救世主5 小时前
学习第六十四行
linux·c语言·开发语言·经验分享·学习
JoneMaster6 小时前
[读书日志]从零开始学习Chisel 第十一篇:Scala的类型参数化(敏捷硬件开发语言Chisel与数字系统设计)
开发语言·学习·scala
power-辰南6 小时前
人工智能学习路线全链路解析
人工智能·学习·机器学习
一只码代码的章鱼6 小时前
go学习笔记
笔记·学习
小登ai学习6 小时前
框架部分面试题学习
java·学习·面试
Chrikk6 小时前
NCCL学习笔记-安装验证
笔记·学习
bohu836 小时前
ros2笔记-4.3 用C++做一个巡逻海龟
c++·笔记·ros2·服务通信