牛客——字符串(尺取法与滑动窗口)

链接:登录—专业IT笔试面试备考平台_牛客网
来源:牛客网
 

题目描述

小N现在有一个字符串S。他把这这个字符串的所有子串都挑了出来。一个S的子串T是合法的,当且仅当T中包含了所有的小写字母。小N希望知道所有的合法的S的子串中,长度最短是多少。

输入描述:

一行一个字符串S。只包含小写字母。S的长度不超过106.

输出描述:

一行一个数字,代表最短长度。数据保证存在一个合法的S的子串。

#include<bits/stdc++.h>
using namespace std;
int book[26]={0};
int check()
{for(int i=0;i<26;i++){if(!book[i])return 0;}return 1;
}
int main()
{string s;cin>>s;int n=s.size();int ans=1e6+10;for(int l=0,r=0;r<n;r++){book[s[r]-'a']++;while(check()){ans=min(ans,r-l+1);book[s[l++]-'a']--;}}cout<<ans;return 0;
}

涉及到字符串的子串长度问题,可以联想到尺取法。

尺取法是一种常用的解决某些问题的算法技巧。它使用两个指针来遍历数组或序列,并根据问题的要求来调整指针的位置,从而求解问题。

尺取法通常用于滑动窗口类型的问题,其中需要在数组或序列中找到满足某些条件的子数组或子序列。尺取法的基本思想是维护一个窗口,通过移动窗口的左右边界来寻找满足条件的子数组或子序列。

尺取法的步骤如下:

  1. 初始化左右指针的位置,通常为数组或序列的开头。
  2. 进入循环,循环条件为右指针小于数组或序列的长度:
    • 根据问题的要求,调整窗口的大小和位置,即移动左右指针。
    • 在每次移动指针后,根据问题的要求更新结果或进行其他操作。
  3. 循环结束后,得到满足条件的子数组或子序列以及相应的结果。

尺取法的优点是时间复杂度较低,通常为 O(n),其中 n 是数组或序列的长度。它适用于一些需要遍历数组或序列的问题,例如求解最长连续子数组的和等。

尺取法的具体实现因问题而异,需要根据具体的问题来调整左右指针的移动规则和条件判断。在应用尺取法时,需要注意边界条件和指针的移动规则,确保算法的正确性。

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

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

相关文章

微信小程序(二十三)获取页面栈及当前页面实例

注释很详细&#xff0c;直接上代码 上一篇 新增内容&#xff1a; 1.页面栈的定义 2.获取当前页面实例 页面栈 当我们从A页面跳到B页面再跳到C页面时&#xff0c;页面栈则是由三个页面的实例组成的数组&#xff0c;A在下标为0的数组中&#xff0c;C在下标为2的数组中 当然&#…

基于二值化图像转GCode的螺旋扫描实现

基于二值化图像转GCode的螺旋扫描实现 什么是双向扫描螺旋扫描代码示例 基于二值化图像转GCode的螺旋扫描实现 什么是螺旋扫描 螺旋扫描&#xff08;Spiral Scanning&#xff09;是激光雕刻中一种特殊的扫描方式&#xff0c;其特点是激光头按照螺旋形状逐渐向外移动&#xf…

再讲 Session 和 Token,彻底弄明白

前言 在构建用户身份管理系统时&#xff0c;选择会话&#xff08;Session&#xff09;还是令牌&#xff08;Token&#xff09;是一个关键决策&#xff0c;取决于系统的需求和特定的使用场景。本文将深入探讨何时适合使用会话&#xff0c;何时适合使用令牌&#xff0c;以帮助开发…

国图公考:考公和考编一样吗?

公务员&#xff1a;是指在各级机关中&#xff0c;符合规定&#xff0c;行使职权&#xff0c;执行公务的人员 事业单位&#xff1a;事业单位是指由国家或社会组织举办&#xff0c;从事教育、科学、文化、卫生、体育等社会公益事业的单位。 公务员和事业编都是有编制的&#xf…

制造业工厂实施MES系统带来的价值是什么?

MES系统的应用能给制造业带来哪些价值&#xff1f;制造企业想要获得更大的利润&#xff0c;就要从生产开始着手。生产制造是工厂的核心,是公司最大的成本来源。企业只有通过信息化的管理模式&#xff0c;从而达到节约成本&#xff0c;提高质量&#xff0c;才能为客户提供更满意…

8.DNS域名解析服务器

目录 1. 概述 1.1. 产生原因 1.2. 作用&#xff1a; 1.3. 连接方式 1.4. 因特网的域名结构 1.4.1. 拓扑&#xff1a; 1.4.2. 分类 1.4.3. 域名服务器类型划分 2. DNS域名解析过程 2.1. 分类&#xff1a; 2.2. 解析图&#xff1a; 2.2.1. 图&#xff1a; 2.2.2. 过…

hot100:26环形链表II

题目链接&#xff1a; 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 算法思想&#xff1a; 在环形链表hot100&#xff1a;25环形链表-CSDN博客这篇博客中&#xff0c;我们解决了如何判断一个链表有环&#xff0c;即快慢指针相遇的地方就证明链表…

【机器学习】监督学习算法之:线性回归

线性回归 1、引言2、线性回归2.1 定义2.2 基本原理2.3 公式2.4 实现2.5 代码示例 3、总结 1、引言 小屌丝&#xff1a;鱼哥&#xff0c;最近机器学习的文章写的不少啊。 小鱼&#xff1a;你还挺细心的哦。 小屌丝&#xff1a;那必须的&#xff0c;我要学习&#xff0c;我要成长…

通过与chatGPT交流实现零样本事件抽取

1、写作动机&#xff1a; 近来的大规模语言模型&#xff08;例如Chat GPT&#xff09;在零样本设置下取得了很好的表现&#xff0c;这启发作者探索基于提示的方法来解决零样本IE任务。 2、主要贡献&#xff1a; 提出了基于chatgpt的多阶段的信息抽取方法&#xff1a;在第一阶…

吉大计网笔记

Osi七层模型 物理层&#xff1a;比特流的透明传输 数据链路层&#xff1a;ip数据包装成帧并传输&#xff0c;处理相邻节点的数据传输。 网络层&#xff1a;选择路由和交换节点&#xff0c;处理任意节点的数据传输。 运输层&#xff1a;主机进程的数据传输服务&#xff0c;端到端…

6个在线网页原型工具的推荐选择

即时设计 即时设计可以说为中国设计师提供了很大的帮助。作为最受欢迎的在线网页原型图设计协作工具之一&#xff0c;在线协作是其核心特征。在线协作工作允许整个团队同时编辑文件&#xff0c;并可以随时随地访问。 团队共享组件库&#xff0c;使成员可以自由上传、下载和使用…

Flink 读取 Kafka 消息写入 Hudi 表无报错但没有写入任何记录的解决方法

博主历时三年精心创作的《大数据平台架构与原型实现:数据中台建设实战》一书现已由知名IT图书品牌电子工业出版社博文视点出版发行,点击《重磅推荐:建大数据平台太难了!给我发个工程原型吧!》了解图书详情,京东购书链接:https://item.jd.com/12677623.html,扫描左侧二维…