力扣2953.统计完全子字符串

力扣2953.统计完全子字符串

  • 分组循环求出每个组 分别算个数

    • 对于每个组 枚举一遍其中有多少种字母
    • 用cnt数组记录每个字母出现次数 check的时候也是暴力枚举cnt中每个字母出现次数
  • **分组循环:**从i(新一组的起点)开始,当满足条件时++,最后退出循环时一定是到了下一个组的起点然后继续循环

  • **Lambda表达式:**auto check = [&](){...}可以调用/修改外部作用域的变量

  • 本题用check就是调用外部的cnt数组

  • string_view:就是用新的变量名表示原字符串

  • 但是不会调用拷贝 是"共享"的

cpp 复制代码
  

class Solution {

int f(string_view s,int k)

{

int res=0;

for(int m=1;m<=26 && k * m <= s.size();m++)

{

int cnt[26]{};

auto check = &{

for(int i=0;i<26;i++)

if(cnt[i] && cnt[i] != k) return ;

res++;

};

for(int right=0;right<s.size();right++)

{

cnt[s[right] - 'a'] ++;

int left = right + 1 - k*m;

if(left >= 0)

{

check();

cnt[s[left] - 'a'] --;

}

}

}

return res;

}

public:

int countCompleteSubstrings(string word, int k) {

int n = word.size();

int ans = 0;

string_view s(word);

for(int i=0;i<n;)

{

int st = i;

for(i++;i<n && abs((int)word[i] - (int)word[i-1]) <= 2;i++);

ans += f(s.substr(st,i-st),k);

}

return ans;

}

};

复制代码

相关推荐
XX風14 小时前
2.1_binary_search_tree
算法·计算机视觉
不想写bug呀14 小时前
买卖股票问题
算法·买卖股票问题
-Try hard-14 小时前
完全二叉树、非完全二叉树、哈希表的创建与遍历
开发语言·算法·vim·散列表
华清远见成都中心14 小时前
GPIO(通用输入输出)面试中高频问题
单片机·面试·职场和发展
茉莉玫瑰花茶14 小时前
C++ 17 详细特性解析(4)
开发语言·c++·算法
long31614 小时前
K‘ 未排序数组中的最小/最大元素 |期望线性时间
java·算法·排序算法·springboot·sorting algorithm
进击的小头15 小时前
FIR滤波器实战:音频信号降噪
c语言·python·算法·音视频
xqqxqxxq15 小时前
洛谷算法1-1 模拟与高精度(NOIP经典真题解析)java(持续更新)
java·开发语言·算法
razelan15 小时前
初级算法技巧 4
算法
砍树+c+v15 小时前
3a 感知机训练过程示例(手算拆解,代码实现)
人工智能·算法·机器学习