翻译密码

 
复制代码
【问题背景】
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;
}
代码
复制代码

 

posted @   浪矢-CL  阅读(434)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App
点击右上角即可分享
微信分享提示