力扣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 cnt26{};

auto check = &{

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

if(cnti && cnti != k) return ;

res++;

};

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

{

cnts\[right - 'a'] ++;

int left = right + 1 - k*m;

if(left >= 0)

{

check();

cnts\[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)wordi - (int)wordi-1) <= 2;i++);

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

}

return ans;

}

};

复制代码

相关推荐
填满你的记忆3 分钟前
《动态规划-基础篇》
算法·动态规划·力扣
禅思院3 分钟前
大列表性能优化 · 面试精讲 · 一
面试·职场和发展·性能优化
进击的荆棘4 分钟前
优选算法——队列+宽搜
数据结构·c++·算法·leetcode·bfs·队列
黎阳之光6 分钟前
虚实同源·数智治水:黎阳之光视频孪生,重构智慧水务新范式
运维·物联网·算法·安全·数字孪生
江屿风8 分钟前
C++OJ题经验总结(竞赛)4
开发语言·c++·笔记·算法·dp·双指针
Deep-w8 分钟前
【MATLAB】微电网四DG逆变器下垂策略与分布式MPC协同控制仿真分析
开发语言·分布式·算法·matlab
酉鬼女又兒8 分钟前
零基础入门计算机网络:定义、分类与核心性能指标
开发语言·计算机网络·考研·青少年编程·职场和发展·php
luweis8 分钟前
企智孪生 ETA (3.5 执行层技术落地)【浙江联保网络 卢伟舜】
网络·人工智能·程序人生·职场和发展·学习方法
手写码匠9 分钟前
华为云Flexus+DeepSeek征文|万字实战:MaaS 推理服务 + Dify 高可用部署 + AI Agent 开发全流程
人工智能·深度学习·算法·aigc
yu85939589 分钟前
基于卡尔曼滤波器的集中式机器人轨迹定位算法
算法·机器人