【NC18386】字符串

题目

字符串

题目又叫字符串,但是这道题是真正的关于字符串的题

思路

这道题可行的我能想出来的思路有两个,一个是二分,先猜测一个答案,然后验证这个答案,但是由于这种方法时间复杂度不如另一种方法:双指针(滑动窗口),所以这里不做记录,只记录双指针的方法:

设置两个指针,一个指针 j j j 标记符合题意的最短字符串的开始,另一个指针 i i i 标记字符串结尾(都是能取到的,闭区间),所以字符串长度就是 i − j + 1 i-j+1 ij+1,初始时两个指针都在字符串开始处 0 0 0,然后让指针 i i i 往前走,直到找出一个符合题意的字符串,此时这个指针标记着字符串的结尾,然后指针 j j j 也开始走,直到走到第一个不符合题意的位置(注意指针所在位置开始的字符串仍然是符合题意的),然后更新答案的值。如此重复即可。

怎么表示一个子串是否符合题意呢?

使用一个哈希表(小写字母常用数组代替哈希表)记录每个字符出现的次数即可,由指针 i i i 遍历到的字符次数加 1 1 1,由指针 j j j 遍历到的字符的次数减 1 1 1(前提是减少之后不为 0 0 0

代码

#include <stdio.h>
#include <string.h>#define N 1000000 + 5
#define M 26/*** @brief 判断当前子串是不是符合题意的** @param st* @param len* @return int*/
int check(int* st, int len) {for (int i = 0; i < len; i++) {if (!st[i]) return 0;}return 1;
}/*** @brief 计算符合题意的子串最小长度** @param s* @return int*/
int solve(const char* s) {int i = 0, j = 0, ans = N;int st[M] = {0};while (s[i]) {st[s[i] - 'a']++;if (check(st, M)) {while (j < i) {// 注意只有当移动了 j 之后还符合题意才移动if (st[s[j] - 'a'] <= 1) {break;}st[s[j] - 'a']--;j++;}if (i - j + 1 < ans) {ans = i - j + 1;}}i++;}return ans;
}int main(void) {char s[N];scanf("%s", s);do {if (strlen(s) < M) {printf("-114514\n");break;}printf("%d\n", solve(s));} while (0);return 0;
}

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

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

相关文章

【React】React表单组件

在React中&#xff0c;表单组件是用来处理用户输入的重要部分。React提供了多种方式来处理表单&#xff0c;包括受控组件&#xff08;Controlled Components&#xff09;和非受控组件&#xff08;Uncontrolled Components&#xff09;。同时&#xff0c;表单组件也涉及到一些交…

第十届 “MathorCup“- B题:养老服务床位需求预测与运营模式研究

目录 摘 要 一、问题重述 二、问题分析 三、模型假设 四、符号说明

基于ACO蚁群优化的UAV最优巡检路线规划算法matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 4.1 蚂蚁移动和信息素更新 4.2 整体优化过程 5.完整程序 1.程序功能描述 基于ACO蚁群优化法的UAV最优巡检路线规划。蚁群优化算法源于对自然界蚂蚁寻找食物路径行为的模拟。在无人机巡检路…

【Pytorch】利用PyTorch实现图像识别

1. 背景介绍 图像识别是计算机视觉领域的一个重要分支&#xff0c;它涉及到让计算机能够像人类一样理解和解释图像中的内容。随着深度学习技术的快速发展&#xff0c;基于卷积神经网络&#xff08;CNN&#xff09;的图像识别方法已经取得了显著的成果&#xff0c;并在许多实际…

哪些属于“法律、行政法规另有规定,依照其规定进行评估/批准”的情况?

哪些属于“法律、行政法规另有规定&#xff0c;依照其规定进行评估/批准”的情况&#xff1f; 除《网络安全法》《数据安全法》和《个人信息保护法》确立的数据和网络安全整体体系外&#xff0c;企业还应当考虑其他相关法律法规的要求。 例如&#xff1a; ✮如根据《中华人民…

Python(Socket) +Unreal(HTTP)

Python&#xff08;Socket&#xff09; Unreal&#xff08;HTTP&#xff09; python&#xff08;Socket&#xff09;:UE&#xff1a;Post请求并发送本机IP 上班咯&#xff0c;好久没记笔记了。。。 局域网 UE的apk&#xff0c;请求Python的Socket 跑起Socket &#xff0c;UE发 …

vue 文件预览(docx、.xlsx、pdf)

1.ifream <iframe src"" ></iframe> 注: src里面是文件地址 2.vue-office 支持vue2和vue3提供docx、.xlsx、pdf多种文档的在线预览方案 2.1安装 #docx文档预览组件 npm install vue-office/docx vue-demi#excel文档预览组件 npm install vue-office…

科技引领趋势:3D元宇宙展厅在各行业中的应用及其未来展望

随着技术的不断进步&#xff0c;3D元宇宙展厅正逐渐成为各行各业展示产品的新选择。相较于传统的线下展厅&#xff0c;3D元宇宙展厅以其独特的优势&#xff0c;为产品展示和品牌推广提供了全新的可能性。 一、虚拟与现实的完美融合 3D元宇宙展厅是指在虚拟世界中构建的三维展览…

设计模式之抽象工厂模式精讲

概念&#xff1a;为创建一组相关或相互依赖的对象提供一个接口&#xff0c;而且无须指定他们的具体类。 抽象工厂模式是工厂方法模式的升级版本。在存在多个业务品种或分类时&#xff0c;抽象工厂模式是一种更好的解决方式。 抽象工厂模式的UML类图如下&#xff1a; 可以看…

1781字符串比大小

//不要用printf去输出string //string可以直接用大于小于号去比较 #include<bits/stdc.h> using namespace std; int main(){ string max"0",s; int len1,len2,mark1,n; cin>>n; cout<<max.size(); for(int i1;i<n;i){ …

Java零基础-集合:遍历

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一个人虽可以走的更快&#xff0c;但一群人可以走的更远。 我是一名后…

数据结构——第5章 树和二叉树

1 二叉树 二叉树和树都属于树形结构&#xff0c;但两者互不包含。即二叉树不是特殊的树。 1.1 二叉树的基本概念 1.2 二叉树的顺序存储 仅适用于完全二叉树 #define MaxSize 100 typedef int ElemType; typedef struct TreeNode{ElemType value;//结点中的数据元素bool isE…

根据疾病名生成病例prompt

prompt 请根据疾病名&#xff1a;" disease_name " 为我生成一份病历。下面是病历内容的要求&#xff1a;病例应严格包含如下几项: 性别&#xff0c;年龄&#xff0c;疾病名&#xff08;必须是" disease_name "&#xff09;&#xff0c;主诉&#xff…

使用Spark单机版环境

在Spark单机版环境中&#xff0c;可通过多种方式进行实战操作。首先&#xff0c;可使用特定算法或数学软件计算圆周率π&#xff0c;并通过SparkPi工具验证结果。其次&#xff0c;在交互式Scala版或Python版Spark Shell中&#xff0c;可以进行简单的计算、打印九九表等操作&…

Object Detection--Loss Function:从IoU到CIoU

本篇总结Loss Function中的IoU系列代码。 1. IoU 交并集&#xff0c;两个框交集面积除以并集面积。&#xff08;论写写画画的重要性&#xff09;&#xff08;找原文看看&#xff09; """ box1[x1, y1, x2, y2] box2[x1, y1, x2, y2] return iou ""…

【WEEK5】 【DAY2】文件上传下载【中文版】

2024.3.26 Tuesday 目录 10.文件的上传和下载10.1.准备工作10.2.基础配置10.2.1.新建名为springmvc-08-file的module10.2.2.新建controller文件夹&#xff0c;applicationContext.xml文件 10.3.文件上传10.3.1.在本模块的pom.xml中导入文件上传的jar包&#xff1a;commons-file…

中国土壤总氮含量空间分布数据

总氮&#xff0c;简称为TN&#xff0c;水中的总氮含量是衡量水质的重要指标之一。总氮的定义是水中各种形态无机和有机氮的总量。包括NO3-、NO2-和NH4等无机氮和蛋白质、氨基酸和有机胺等有机氮&#xff0c;以每升水含氮毫克数计算。常被用来表示水体受营养物质污染的程度。 中…

机械结构篇之四足机器人身体设计

欢迎关注微信公众号 “四足机器人研习社”&#xff0c;本公众号的文章和资料和四足机器人相关&#xff0c;包括行业的经典教材、行业资料手册&#xff0c;同时会涉及到职业知识学习及思考、行业发展、学习方法等一些方面的文章。 目录 1.躯干 2.腿部结构 a.轮腿结合式 …

LLMs之Grok-1:run.py文件解读—运行语言模型实现推理—即基于用户的输入文本利用grok_1语言模型来生成文本

LLMs之Grok-1&#xff1a;run.py文件解读—运行语言模型实现推理—即基于用户的输入文本利用grok_1语言模型来生成文本 目录 run.py文件解读—运行语言模型实现推理—即基于用户的输入文本利用grok_1语言模型来生成文本 概述 1、加载预训练的语言模型 grok_1 1.1、定义模型…

Python之数据分析二

一、Python之数据类型 当讲解Python中的数据类型时&#xff0c;可以通过代码来示范每种数据类型的特点和用法。以下是Python中常见的几种数据类型&#xff1a; 1.数字&#xff08;Numbers&#xff09;类型 包括整数&#xff08;int&#xff09;、浮点数&#xff08;float&am…