统计完全子字符串

很不错的计数问题,用到了分组循环技巧和滑动窗口 代码的实现方式也非常值得多看

cpp 复制代码
class Solution {
public:
    int f(string s,int k){
        int res = 0;
        for(int m=1;m<=26&&k*m<=s.size();++m){
            int cnt[27]{};
            auto check=[&](){
                for(int i=0;i<=26;++i){
                    if(cnt[i]&&cnt[i]!=k)return;
                }
                res++;
            };

            for(int r=0;r<s.size();++r){
                cnt[s[r]-'a']++;
                int l = r+1-k*m;
                if(l>=0){
                    check();
                    cnt[s[l]-'a']--;
                }
            }
        }
        return res;
    }
    int countCompleteSubstrings(string word, int k) {
        int n = word.size();
        int res = 0;
        for(int i=0;i<n;){
            int start = i;
            ++i;
            while(i<n&&abs(int(word[i]-word[i-1]))<=2)++i;
            res+=f(word.substr(start,i-start),k);
        }
        return res;
    }
};
相关推荐
阿贵---5 分钟前
C++中的RAII技术深入
开发语言·c++·算法
Traced back11 分钟前
怎么用 Modbus 让两个设备互相通信**,包含硬件接线、协议原理、读写步骤,以及 C# 实操示例。
开发语言·c#
NAGNIP13 分钟前
面试官:深度学习中经典的优化算法都有哪些?
算法
PiKaMouse.31 分钟前
navigation2-humble从零带读笔记第一篇:nav2_core
c++·算法·机器人
木井巳37 分钟前
【递归算法】子集
java·算法·leetcode·决策树·深度优先
lightqjx1 小时前
【算法】二分算法
c++·算法·leetcode·二分算法·二分模板
娇娇yyyyyy2 小时前
QT编程(17): Qt 实现自定义列表模型
开发语言·qt
ms_27_data_develop2 小时前
Java枚举类、异常、常用类
java·开发语言
Irissgwe2 小时前
进程间通信
linux·服务器·网络·c++·进程间通信