小火山 zzuli 1912(密码)

2024-08-21 19:18
文章标签 密码 火山 zzuli 1912

本文主要是介绍小火山 zzuli 1912(密码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

小火山的爱情密码

  

Description

小火山获得了一个字符串,然而大火山让小火山从里面截取一段字符串,并且让小火山截取的字符串满足一些字符达到一定数量。
小火山觉得很容易,但是他想要知道他至少得截取多长的字符串。

Input

首先是一个整数t(t<=100),表示测试数据组数。接下来是两个整数n和m(n<=10000, m<=10),n表示字符串的长度,m表示要满足一定数量的字符
的种类.(字符只包含小写英文字母)
个数(没有重复字符种类),然后有m行,每行第一个是一个字符,然后是一个整数x(x<=50),表示这种字符的的要求数量。

Output

输出最小长度,如果达不到要求输出-1

Sample Input

1
6 3
cancan
c 2
a 2
n 2

Sample Output

6

 题解:二分/尺取。没想到怎么记录要求的字母,看了代码才知道可以用(字符-'a')转化成数字进行记录。

//二分 
#include<cstdio>
#include<cstring>
using namespace std;char s[10101];
int n,m;
int num1[10101][27];//不能随意开成num1[10101][10101],会超内存
[int num2[10101];int judge1 (int x,int y){int j;for (j=0;j<26;j++){if (!num2[j]) continue;if (num1[x+y][j]-num1[x][j]+(s[x]==j+'a')<num2[j])//说明所求的应该在右区间return 0;}		return 1;
}int judge (int mid){int i;if (mid ==0) return 0;for (i=0;i<=n-mid;i++){if (judge1(i,mid-1)) return 1;}return 0;
}
int main(){int t;int i,j;char a;int b;scanf ("%d",&t);while (t--){memset(num1,0,sizeof(num1));scanf ("%d %d",&n,&m);scanf ("%s",s);num1[0][s[0]-'a']++;for (i=1;i<n;i++){for (j=0;j<26;j++){num1[i][j]+=num1[i-1][j];}num1[i][s[i]-'a']++;//记录字符串中字符的位置及个数,i为位置,j为该字符}memset(num2,0,sizeof(num2));for (i=0;i<m;i++){getchar();scanf ("%c %d",&a,&b);num2[a-'a']=b;}int l=m,r=n,ans=-1;while (l<=r){int mid=(l+r)/2;if (judge(mid)){ans=mid;r=mid-1;}elsel=mid+1;}printf ("%d\n",ans);	}return 0;
}

尺取后补

这篇关于小火山 zzuli 1912(密码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1094047

相关文章

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

mysql重置root密码的完整步骤(适用于5.7和8.0)

《mysql重置root密码的完整步骤(适用于5.7和8.0)》:本文主要介绍mysql重置root密码的完整步骤,文中描述了如何停止MySQL服务、以管理员身份打开命令行、替换配置文件路径、修改... 目录第一步:先停止mysql服务,一定要停止!方式一:通过命令行关闭mysql服务方式二:通过服务项关闭

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

超级 密码加密 解密 源码,支持表情,符号,数字,字母,加密

超级 密码加密 解密 源码,支持表情,符号,数字,字母,加密 可以将表情,动物,水果,表情,手势,猫语,兽语,狗语,爱语,符号,数字,字母,加密和解密 可以将文字、字母、数字、代码、标点符号等内容转换成新的文字形式,通过简单的文字以不同的排列顺序来表达不同的内容 源码截图: https://www.httple.net/152649.html

mysql导出导入数据和修改登录密码

导出表结构: mysqldump -uroot -ppassword -d dbname tablename>db.sql; 导出表数据: mysqldump -t dbname -uroot -ppassword > db.sql 导出表结构和数据(不加-d): mysqldump -uroot -ppassword dbname tablename > db.sql;

Ubuntu 环境下ssh的安装、使用以及免密码登录

以两台机器为例:     A12.12.10.11B12.12.10.13 安装: Ubuntu默认安装了ssh客户端,只需要在被登录的机器上安装ssh服务器即可: $ sudo apt-get install openssh-server     启动ssh服务器: $ sudo /etc/init.d/ssh start 查看是否启动成功: $ ps -ef |grep

ubuntu 20.04 一直卡在登录界面,即使密码正确也无法登录(失败记录)

ubuntu 20.04 一直卡在登录界面,即使密码正确也无法登录 这次是装实体机,一次失败的尝试。。。 名称型号CPUIntel Xeon E5-2673 V3GPURTX 3060 mobile 安装的时候不要选install third-party software for graphics and Wi-fi hardware and additional media

oracle密码维护

查看密码是否可以重复使用 SQL> select PROFILE,RESOURCE_NAME,LIMIT from dba_profiles where profile='DEFAULT' and resource_type ='PASSWORD'; PROFILE                        RESOURCE_NAME                    LIMIT ----