hdu 4300 拓展kmp

题目大意:

输入样例个数,每个样例有两行,第一行是26个字母,分别代表a~z加密后的密文;第二行代表一串密文+明文,密文一定是完整的,但明文可能不完整,让你输出最短的(密文+明文);

基本思路:

拓展kmp,因为密文是完整的,所以它的长度必然是一半以上,所以把前一半转换成明文放到另一个数组里,然后后半部分原封不动的放到该数组里,然后拓展kmp,求一下next,然后从一半以后一直往后找,找到的话,就跳出,然后基本把把问题解决了;

代码如下:

#include<cstdio>
#include<cstring>
#include<algorithm>

using namespace std;

typedef  long long ll;
const int inf = 0x3f3f3f3f;
const int maxn = 100000+10;

int nx[maxn],ex[maxn];
char S[maxn],T[maxn];
char s1[maxn],a[27],b[27];
int lent,lens;
void getNext(){
    nx[0]=lent;
    int j=0;
    while(j+1<lent&&T[j]==T[j+1]) j++;
    nx[1]=j;
    int k=1;
    for(int i=2;i<lent;i++){
        int p=k+nx[k]-1;
        int l=nx[i-k];
        if(i+l<p+1) nx[i]=l;
        else{
            j=max(0,p-i+1);
            while(i+j<lent&&T[i+j]==T[j]) j++;
            nx[i]=j;
            k=i;
        }
    }
}
/*
void exkmp(){
    int j=0;
    while(j<lens&&j<lent&&S[j]==T[j]) j++;
    ex[0]=j;
    int k=0;
    for(int i=1;i<lens;i++){
        int p=k+nx[k]-1;
        int l=nx[i-k];
        if(l+i<p+1) ex[i]=-l;
        else{
            j=max(0,p-i+1);
            while(i+j<lens&&j<lent&&S[i+j]==T[j]) j++;
            ex[i]=j;
            k=i;
        }
    }
}
*/
int main(){
    int cas;
    scanf("%d",&cas);
    while(cas--){
        scanf("%s%s",a,s1);
        for(int i=0;i<26;i++) b[a[i]-‘a‘]=i+‘a‘;
        int len=strlen(s1);
        for(int i=0;i<(len+1)/2;i++) T[i]=b[s1[i]-‘a‘];
        for(int k=(len+1)/2;k<=len;k++) T[k]=s1[k];
        lent=strlen(T);
        getNext();
        int k;
        for(k=(len+1)/2;k<len;k++){
            if(nx[k]==len-k) break;
        }
        printf("%s",s1);
        for(int i=len-k;i<k;i++) printf("%c",b[s1[i]-‘a‘]);
        printf("\n");
    }
    return 0;
}

  

时间: 2024-10-10 04:53:20

hdu 4300 拓展kmp的相关文章

HDU 6153 拓展KMP (2017CCPC)

A Secret Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 256000/256000 K (Java/Others)Total Submission(s): 975    Accepted Submission(s): 372 Problem Description Today is the birthday of SF,so VS gives two strings S1,S2 to SF as a present,whi

HDU 4300 Clairewd&#39;s message ( 拓展KMP )

题意 : 给你一个包含26个小写字母的明文密文转换信息字符串str,第一个表示'a'对应的密文是str[0].'b'对应str[1]--以此类推.接下来一行给你一个另一个字符串,这个字符串由密文+明文组成,但是现在后面部分的明问可能有不完整的情况(也有可能缺失只包含密文),问你现在最少需要补充多多少个字符串才能使得字符串变成完整的满足==>密文+密文对应的明文 组成的字符串,将这个完整的字符串输出出来. 分析 : 冷静分析一下可以发现,在给出的残缺字符串中,前面的一半肯定是属于密文的!如果不是这

HDU 4300 Clairewd‘s message 拓展KMP入门

HDU 4300 Clairewd's message 拓展KMP入门 题意 原题链接 这个题关键是要读懂题意,我做的时候就没有读懂,泪.题意是说给你的一个两个字符串,一个是26个字母密码表,依次对应替换的字母.然后给你一个字符串,这个字符串是不完整的(完整的应该是前半部分是加密的,后半部分是解密了的),然而,给你的字符串一定是加密的部分+一部分解密的部分(可以是全部,也可以是没有),让你求出最短的完整字符串,包括密文和明文: 解题思路 考虑给出的字符串S加密部分一定全部给出,所以给出的字符串的

HDU 4300 Clairewd’s message(初遇拓展KMP)

昨晚一不小心学了拓展KMP,被虐了一晚,最终是这份资料救了我...http://wenku.baidu.com/view/8e9ebefb0242a8956bece4b3.html 说得简单易懂. 然后学了kuangbin的模版: /* * 扩展KMP算法 */ //next[i]:x[i...m-1]与x[0...m-1]的最长公共前缀 //extend[i]:y[i...n-1]与x[0...m-1]的最长公共前缀 void pre_EKMP(char x[],int m,int next[

hdu 4300 Clairewd’s message (KMP)

给定一个翻译表,即第i个字母用哪个字母表示 再给一个串,里面前面为密文,后面为明文,密文一定是完整的,但明文不完整或可能没有 求这个完整的前面密文后面明文的串 # include <stdio.h> # include <algorithm> # include <string.h> using namespace std; int len; int next[100010]; char a1[100010],a2[100010],a3[100010]; void Ge

HDU - 3613 Best Reward(manacher或拓展kmp)

传送门:HDU - 3613 题意:给出26个字母的价值,然后给你一个字符串,把它分成两个字符串,字符串是回文串才算价值,求价值最大是多少. 题解:这个题可以用马拉车,也可以用拓展kmp. ①Manacher:先记录下第i个字符的价值,然后求前缀和.然后遍历分的位置,分别判断前半段和后半段是否为回文串,是回文串的加上这段的价值(前缀和相减),更新最大价值. 1 #include<bits/stdc++.h> 2 using namespace std; 3 4 int p[1000100],v

HDU 3613 Best Reward(求前后缀回文 拓展KMP or Manacher)

题目大意: 给个字符串X,要把X分成两段T1,T2,每个字母都有一个对应的价值,如果T1,T2是回文串(从左往右或者从右往左读,都一样),那么他们就会有一个价值,这个价值是这个串的所有字母价值之和,如果不是回文串,那么这串价值就为0.问最多能获得多少价值? 思路: 把字符串X逆序后得到字符串Y 让X去匹配Y ,匹配的长度满足extend[i] + i == len,  len=|X|.    的那么X与y的匹配部分是回文串,这不难理解,画图即可 总复杂度是O(n),由于这是求前缀和后缀的回文,用

HDU 3613 Best Reward(拓展KMP算法求解)

题目链接: https://cn.vjudge.net/problem/HDU-3613 After an uphill battle, General Li won a great victory. Now the head of state decide to reward him with honor and treasures for his great exploit. One of these treasures is a necklace made up of 26 differe

Simpsons’ Hidden Talents HDU - 2594(拓展kmp)

Sample Input clinton homer riemann marjorie Sample Output 0 rie 3 看输出才题意...拓展kmp特征很明显嘛....注意开始就匹配到尾的情况 #include <iostream> #include <cstdio> #include <sstream> #include <cstring> #include <map> #include <set> #include &