zoukankan      html  css  js  c++  java
  • 翻译密码

     
    【问题背景】
    zhx 和他的妹子聊天。
    【问题描述】
    考虑一种简单的加密算法。
    假定所有句子都由小写英文字母构成,对于每一个字母,我们将它唯一地映
    射到另一个字母。例如考虑映射规则:
    a->b, b->c, c->d, d->a. 那么单词 bad 就会被映射为 cba。这个映射规则的“逆
    映射规则”为: b->a, c->b, d->c, a->d。 对于密文 cba, 我们很容易将它解密为 bad。
    当然,这样的映射需要保证每一个字母映射到的字母是不同的(即不可以出
    现两个不同的字母映射到同一个字母,否则将会无法解密) 。
    一种常见的密码攻击方式被称为已知明文攻击。具体地,在你不知道映射表
    的情况下,给你一段明文和对应的密文,你可以推导出一些的映射规则,下一次
    你收到一条密文,你就可能可以解密它。现在你需要完成这样的一个系统。
    【输入格式】
    第一行包含一个字符串,仅包含小写字母,表示一段明文。
    第二行包含一个字符串,仅包含小写字母,表示这段明文对应的密文,保证
    两行长度相同。
    第三行包含一个字符串,仅包含小写字母,表示你需要解密的密文。
    【输出格式】
    输出共一行,表示输入中第三行密文对应的明文。如果不能解密,输出
    “ERROR”(不包含引号) 。注意输入可能出现不自恰的情况。
    【样例输入】
    ab
    cc
    cc
    【样例输出】
    ERROR
    【样例输入】
    ab
    ab
    c
    【样例输出】
    ERROR
    【样例输入】
    abcde
    bcdea
    cad
    【样例输出】
    bec
    【数据范围与规定】
    对于100%的数据,所有字符串长度<=1000
    题干

    考虑共有26个字母,知道25个之后最后一个也就知道了。

    #include<iostream>
    #include<cstdio>
    #include<algorithm>
    #include<cstring>
    #include<vector>
    #include<queue>
    #include<math.h>
    using namespace std;
    char a[1010],b[1010],c[1010],d[1010];
    int f[30],len1,len2,x,y;
    int vis[30],yy,tot,xx;
    int main()
    {
        freopen("enc.in","r",stdin);
        freopen("enc.ans","w",stdout);
        cin>>(a+1)>>(b+1)>>(c+1);
        len1=strlen(a+1);
        for(int i=1;i<=len1;i++)
        {
            x=b[i]-'a'+1; y=a[i]-'a'+1;
            if(f[x]&&f[x]!=y)    
            {
                cout<<"ERROR";
                return 0;
            }
            f[x]=y;vis[y]=1;
        }
        
        for(int i=1;i<=26;i++)    if(!vis[i])    tot++,yy=i;
        if(tot==1)
        {
            tot=0;
            for(int i=1;i<=26;i++)
            if(!f[i])    tot++,xx=i;
            if(tot==1)    f[xx]=yy;
        }
        len2=strlen(c+1);
        for(int i=1;i<=len2;i++)
        {
            x=c[i]-'a'+1;
            if((!f[x]))
            {
                cout<<"ERROR";
                return 0;
            }
            d[i]='a'+f[x]-1;
        }
        for(int i=1;i<=len2;i++)
        cout<<d[i];
        return 0;
    }
    代码
  • 相关阅读:
    Hadoop常用命令介绍
    hadoop异常: java.io.EOFException: Unexpected end of input stream
    Python操作MySQL
    Python常用模块安装
    pyenv激活虚拟环境失败
    Jarvis OJ A Piece Of Cake
    JarvisOJ BASIC 德军的密码
    JarvisOJ BASIC -.-字符串
    HDU 1003 Max Sum
    洛谷 P2119 魔法阵
  • 原文地址:https://www.cnblogs.com/CLGYPYJ/p/7380499.html
Copyright © 2011-2022 走看看