HDU - 4300 Clairewd’s message (拓展kmp)
题意:这个题目好难读懂,,先给你一个字母的转换表,然后给你一个字符串密文+明文,密文一定是全的,但明文不一定是全的,求最短的密文和解密后的明文;
题解:由于密文一定是全的,所以他的长度一定大于整个字符串的一半。将这一半先解密,然后和后缀对比一下,求最长的公共前缀。那么就转换为了拓展kmp问题。
1 #include<bits/stdc++.h>
2 using namespace std;
3
4 const int maxn=100010; //字符串长度最大值
5 int nt[maxn],ex[maxn]; //ex数组即为extend数组
6 char a[maxn],b[maxn],c[maxn];
7 map<char,char> mp;
8
9 //预处理计算next数组
10 void GETNEXT(char *str)
11 {
12 int i=0,j,po,len=strlen(str);
13 nt[0]=len; //初始化nt[0]
14 while(str[i]==str[i+1]&&i+1<len) i++; //计算nt[1]
15 nt[1]=i;
16 po=1; //初始化po的位置
17 for(i=2;i<len;i++){
18 if(nt[i-po]+i<nt[po]+po) nt[i]=nt[i-po]; //第一种情况,可以直接得到nt[i]的值
19 else{ //第二种情况,要继续匹配才能得到nt[i]的值
20 j=nt[po]+po-i;
21 if(j<0) j=0; //如果i>po+nt[po],则要从头开始匹配
22 while(i+j<len&&str[j]==str[j+i]) j++; //计算nt[i]
23 nt[i]=j;
24 po=i; //更新po的位置
25 }
26 }
27 }
28
29 //计算extend数组
30 void EXKMP(char *s1,char *s2)
31 {
32 int i=0,j,po,len=strlen(s1),l2=strlen(s2);
33 GETNEXT(s2); //计算子串的next数组
34 while(s1[i]==s2[i]&&i<l2&&i<len) i++; //计算ex[0]
35 ex[0]=i;
36 po=0; //初始化po的位置
37 for(i=1;i<len;i++){
38 if(nt[i-po]+i<ex[po]+po) ex[i]=nt[i-po]; //第一种情况,直接可以得到ex[i]的值
39 else{ //第二种情况,要继续匹配才能得到ex[i]的值
40 j=ex[po]+po-i;
41 if(j<0) j=0; //如果i>ex[po]+po则要从头开始匹配
42 while(i+j<len&&j<l2&&s1[j+i]==s2[j]) j++; //计算ex[i]
43 ex[i]=j;
44 po=i; //更新po的位置
45 }
46 }
47 }
48
49 int main()
50 {
51 int t;
52 cin>>t;
53 while(t--){
54 cin>>a>>b;
55 int len1=strlen(a);
56 int len2=strlen(b);
57 for(int i=0;i<len1;i++)
58 mp[a[i]]='a'+i;
59 for(int i=0;i<len2;i++)
60 c[i]=mp[b[i]];
61 c[len2]=0;
62 EXKMP(b,c);
63 int k;
64 for(k=0;k<len2;k++)
65 if(k+ex[k]>=len2&&k>=ex[k]) break;
66 for(int i=0;i<k;i++) cout<<b[i];
67 for(int i=0;i<k;i++) cout<<mp[b[i]];
68 cout<<endl;
69 }
70 return 0;
71 }
HDU - 4300 Clairewd’s message (拓展kmp)的更多相关文章
- HDU 4300 Clairewd's message ( 拓展KMP )
题意 : 给你一个包含26个小写字母的明文密文转换信息字符串str,第一个表示'a'对应的密文是str[0].'b'对应str[1]……以此类推.接下来一行给你一个另一个字符串,这个字符串由密文+明文 ...
- hdu 4300 Clairewd’s message(扩展kmp)
Problem Description Clairewd is a member of FBI. After several years concealing in BUPT, she interce ...
- hdu 4300 Clairewd’s message(kmp/扩展kmp)
题意:真难懂.. 给出26个英文字母的加密表,明文中的'a'会转为加密表中的第一个字母,'b'转为第二个,...依次类推. 然后第二行是一个字符串(str1),形式是密文+明文,其中密文一定完整,而明 ...
- hdu 4300 Clairewd’s message KMP应用
Clairewd’s message 题意:先一个转换表S,表示第i个拉丁字母转换为s[i],即a -> s[1];(a为明文,s[i]为密文).之后给你一串长度为n<= 100000的前 ...
- hdu 4300 Clairewd’s message 字符串哈希
Clairewd’s message Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- hdu 4300 Clairewd’s message(具体解释,扩展KMP)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4300 Problem Description Clairewd is a member of FBI. ...
- HDU 4300 Clairewd’s message(KMP+思维)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4300 题目大意:题目大意就是给以一段字符xxxxzzz前面x部分是密文z部分是明文,但是我们不知道是从 ...
- HDU 4300 Clairewd’s message(扩展KMP)
思路:extend[i]表示原串以第i開始与模式串的前缀的最长匹配.经过O(n)的枚举,我们能够得到,若extend[i]+i=len且i>=extend[i]时,表示t即为该点之前的串,c即为 ...
- HDU 4300 Clairewd’s message(扩展KMP)题解
题意:先给你一个密码本,再给你一串字符串,字符串前面是密文,后面是明文(明文可能不完成整),也就是说这个字符串由一个完整的密文和可能不完整的该密文的明文组成,要你找出最短的密文+明文. 思路:我们把字 ...
随机推荐
- VsCode/Pycharm配合python env 使用
前言 用惯了vscode,这几天试了一下pycharm,还是回来了. pycharm一个好处就是python env 环境支持的比较好, vscode虽然也支持但是要改一些东西 env的使用查看我的上 ...
- 【C++】《C++ Primer 》第十七章
第十七章 标准库特殊设施 一.tuple类型 tuple是类似pair的模板,每个pair的成员类型都不相同,但每个pair都恰好有两个成员. 不同的tuple类型的成员类型也不相同,一个tuple可 ...
- docker迁入迁出mysql
docker迁出mysql数据库 测试环境: docker服务器 mysql服务器 IP 192.168.163.19 192.168.163.16 操作系统 CentOS7.8 CentOS7.8 ...
- 【Linux】centos7中 root家目录中perl5文件夹无法删除问题解决
由于新项目上线,安装了一些perl的一些包 但是发现,在/root下有一个perl5/的文件夹,删除后,重新登录又会出现,很是烦人,而且他还没有内容,就是一个空文件 那么着手搞掉他 环境:centos ...
- VS2019项目docker启动且访问SQLSERVER数据库配置
VS2019编译.调试的Blazor纯前台项目,使用控制台启动,去连接纯后台的API项目,使用docker启动,并且通过EFCore访问SQLSERVER数据库,有几个地方需要修改配置: 一.前台连后 ...
- CTFHub - Web(四)
最近又是每天忙到裂开,,,淦 xss: 反射型: 1.第一个输入框与下面Hello后的内容相同,猜测可以通过该输入,改变页面内容. 测试语句: <script>alert(1)</s ...
- Python输出有颜色的文字
原创链接: https://www.cnblogs.com/easypython/p/9084426.html 我们在使用python运维与开发的过程中,经常需要打印显示各种信息.海量的信息堆砌在 ...
- 入门OJ:扫雪
扫雪1 题目描述 大雪履盖了整个城市,市政府要求冬季服务部门尽快将一些街道(列在一份清单中)的积雪清除掉以恢复交通,整个城市由许多交叉路口和街道构成,当然任意两个交叉路口都是直接或间接连通的,清单给出 ...
- 它真正的父进程在fork出子进程后就先于子进程exit退出了,所以它是一个由init继承的孤儿进程
[Linux编程]守护进程(daemon)详解与创建_mick_seu的博客-CSDN博客_linux daemon https://blog.csdn.net/woxiaohahaa/article ...
- http 和 https 有何区别?如何灵活使用?
http是HTTP协议运行在TCP之上.所有传输的内容都是明文,客户端和服务器端都无法验证对方的身份. https是HTTP运行在SSL/TLS之上,SSL/TLS运行在TCP之上.所有传输的内容都经 ...