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

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

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

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

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

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

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

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

  •   
    

    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;
    }
    };

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/22462.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CentOS 7基础操作03_Linux命令的分类

1、Linux命令的分类 Linux命令的执行必须依赖于 Shell命令解释器。Shell实际上是在Linux操作系统中运行的一种特殊程序,它位于操作系统内核与用户之间&#xff0c;负责接收用户输入的命令并进行解释&#xff0e;将需要执行的操作传递给系统内核执行&#xff0c;Shell在用户和内…

搜维尔科技: 使用 Xsens 和 HTC Vive进行电影制作案例

搜维尔科技&#xff1a; 使用 Xsens 和 HTC Vive进行电影制作案例 搜维尔科技&#xff1a; 使用 Xsens 和 HTC Vive进行电影制作案例

全域外卖平台是什么?有哪些系统可以推荐?

随着本地生活下半场的开启&#xff0c;以团购外卖为代表的一系列相关业务也迈入了全域时代。在此背景下&#xff0c;全域外卖赛道正式兴起&#xff0c;全域外卖平台也随之备受瞩目。 作为创业的一大新风口&#xff0c;全域外卖囊括了公域和私域内所有的外卖业务&#xff0c;主…

基础篇03——SQL约束

概述 约束示例 完成以下案例&#xff1a; create table user (id int primary key auto_increment comment 主键,name varchar(10) not null unique comment 姓名,age tinyint unsigned check ( age > 0 and age < 120 ) comment 年龄,status char(1) default 1 commen…

嵌入式C语言--Pragma Section与Map文件

嵌入式C语言–Pragma Section与Map文件 嵌入式C语言--Pragma Section与Map文件 嵌入式C语言--Pragma Section与Map文件一. Pragma修饰符二. Map文件1&#xff09;什么是map文件2&#xff09;map文件的构成3&#xff09;常用的段映射地址4&#xff09;map文件生成 三. Section修…

HAL_UART_IRQHandler(UART_HandleTypeDef *huart)分析

//接收没错误&#xff1a;执行UART_Receive_IT(huart) //接收有错误&#xff1a;执行UART_Receive_IT(huart)、HAL_UART_ErrorCallback(huart) void HAL_UART_IRQHandler(UART_HandleTypeDef *huart) {uint32_t isrflags READ_REG(huart->Instance->SR);uint32_t cr1…

java项目部署脚本

一、java项目部署脚本示例 在Java项目中&#xff0c;部署脚本通常依赖于项目的构建工具&#xff08;如Maven或Gradle&#xff09;以及部署环境&#xff08;如Docker、Tomcat、Kubernetes等&#xff09;。以下是一个基于Maven和Shell脚本的Java项目部署示例&#xff0c;假设我们…

8*8LED点阵点亮一个点

#include<reg51.h> typedef unsigned int u16; //对系统默认数据进行重定义 typedef unsigned char u8; //定义74HC595控制管脚 sbit SRCLKP3^6; //移位寄存器时钟输入 sbit RCLKP3^5; //存储寄存器时钟输入 sbit SERP3^4; //串…

SpaceX: 太空火箭自主精准着陆

本文是根据Lars Blackmore在16年的一篇公开论文翻译而来&#xff0c;虽然有些早而且是科普文章&#xff0c;但是可以初见一些SpaceX火箭着陆的细节&#xff0c;后面我会对spaceX landing control 技术主管MIT博士期间研究火箭控制算法的论文进行讲解&#xff0c;敬请期待。 Lar…

Linux系统常用命令

Linux 系统常用命令 1、文件操作2、目录操作 1、文件操作 创建文件&#xff1a; touch 文件名 创建文件并编辑&#xff1a;vim 文件名 查看文件全部内容&#xff1a;cat 文件名 带行号查看文件内容&#xff1a; cat -n file 查看文件内容并监视内容更新&#xff1a; 以翻页形…

【电机】步进电机相关指标

一 静态指标&#xff1a; 相数&#xff1a;线圈的组数&#xff0c;两相步进电机步距角一般为 1.8&#xff0c;三相的步进电机步距角为 1.2&#xff0c;相数越多步距角越小。 步距角&#xff1a;一个脉冲信号所对应的电机转动的角度&#xff0c;这个步距角他不一定是电机实际工…

OpenEuler华为欧拉系统安装—从零开始,小白也能学会

介绍 openEuler&#xff08;欧拉&#xff09;是一款开源操作系统。 当前openEuler内核源于Linux&#xff0c;支持鲲鹏及其它多种处理器&#xff0c; 能够充分释放计算芯片的潜能&#xff0c;是由全球开源贡献者构建的高效、 稳定、安全的开源操作系统&#xff0c;适用于数据库…

JVM运行数据区-Java堆

Java堆 堆区&#xff08;Heap区&#xff09;是JVM运行时数据区占用内存最大的一块区域&#xff0c;每一个JVM进程只存在一个堆区&#xff0c;它在JVM启动时被创建&#xff0c;JVM规范中规定堆区可以是物理上不连续的内存&#xff0c;但必须是逻辑上连续的内存。 1、堆区是线程…

Java面试题-基础

Java面试题-基础 1、Java语言有哪些特点&#xff1f;2、面向对象和面向过程的区别是什么&#xff1f;3、说说标识符的命名规则&#xff1f;4、说说Java八种基本数据类型的大小以及他们的封装类&#xff1f;5、instanceof关键字有什么作用&#xff1f;6、自动装箱与自动拆箱是什…

「网络编程」基于 UDP 协议实现回显服务器

&#x1f387;个人主页&#xff1a;Ice_Sugar_7 &#x1f387;所属专栏&#xff1a;计网 &#x1f387;欢迎点赞收藏加关注哦&#xff01; 实现回显服务器 &#x1f349;socket api&#x1f349;回显服务器&#x1f34c;实现&#x1f95d;服务器&#x1f95d;客户端 &#x1f3…

纯血鸿蒙实战开发—如何添加顶部tab页面

1.Tabs组件 Tabs组件的页面组成包含两个部分&#xff0c;分别是TabContent和TabBar。TabContent是内容页&#xff0c;TabBar是导航页签栏. 根据不同的导航类型&#xff0c;布局会有区别&#xff0c;可以分为底部导航、顶部导航、侧边导航&#xff0c;其导航栏分别位于底部、顶…

react基础学习 JSX

JSX的测试网站 Babel Babel 可以测试代码的效果 JSX实现map列表 注意 key不一样&#xff08;使用遍历的时候&#xff09; 简单条件渲染 复杂条件渲染 绑定事件 function App() {const colorse (e)>{console.log("测试点击",e);}const colorse1 (name)>{…

代码随想录训练营第六十天 | 84.柱状图中最大的矩形

84.柱状图中最大的矩形 题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 文档讲解&#xff1a;代码随想录 视频讲解&#xff1a;单调栈&#xff0c;又一次经典来袭&#xff01; LeetCode&#xff1a;84.柱状图中最大的矩形_哔哩哔哩_bilibili 状态&#xff1a;未…

地理信息科学中的大数据挑战

在信息化爆炸的时代&#xff0c;地理信息科学&#xff08;GIScience&#xff09;正经历着前所未有的变革&#xff0c;其中&#xff0c;地理空间大数据的涌现为科学研究与应用带来了前所未有的机遇与挑战。作为地理信息与遥感领域的探索者&#xff0c;本文旨在深入剖析地理空间大…

揭秘HubSpot集客营销:如何吸引并转化全球潜在客户

随着全球数字化浪潮的推进&#xff0c;企业出海已经成为许多公司扩大市场、增加品牌曝光度的重要战略。HubSpot集客营销作为一种以客户为中心、数据驱动的营销策略&#xff0c;为企业在海外市场的成功提供了强有力的支持。作为HubSpot亚太地区的合作伙伴&#xff0c;NetFarmer将…