题意翻译

【题目描述】 古罗马帝国有一个拥有各种部门的强大政府组织。其中一个部门就是保密服务部门。为了保险起见,在省与省之间传递的重要文件中的大写字母是加密的。当时最流行的加密方法是替换和重新排列。 替换方法是将所有出现的字符按照一个规则替换,比如ABCDEFGHIJKLMNOPQRSTUVWXYZ到BCDEFGHIJKLMNOPQRSTUVWXYZA,如果原词是 “VICTORIOUS” 则它变成 “WJDUPSJPVT”。 排列方法改变原来单词中字母的顺序。例如:将顺序<2, 1, 5, 4, 3, 7, 6, 10, 9, 8>应用到 “VICTORIOUS” 上,则得到"IVOTCIRSUO"。 人们很快意识到单独应用替换方法或排列方法加密,都是很不保险的。但是如果结合这两种方法,在当时就可以得到非常可靠的加密方法。所以,很多重要信息先使用替换方法加密,再将加密的结果用排列的方法加密。用两种方法结合就可以将"VICTORIOUS" 加密成"JWPUDJSTVP"。 考古学家最近在一个石台上发现了一些信息。初看起来它们毫无意义,所以有人设想它们可能是用替换和排列的方法被加密了。人们试着解读了石台上的密码,现在他们想检查解读的是否正确。他们需要一个计算机程序来验证,你的任务就是写这个验证程序。 【输入描述】 输入有两行。第一行是石台上的文字。文字中没有空格,并且只有大写英文字母。第二行是被解读出来的加密前的文字。第二行也是由大写英文字母构成的。两行字符数目的长度都不超过100。 【输出描述】 如果第二行经过某种加密方法后可以产生第一行的信息,输出 “YES”,否则输出"NO"

输入输出样例

输入 #1

JWPUDJSTVP
VICTORIOUS
MAMA
ROME
HAHA
HEHE
AAA
AAA
NEERCISTHEBEST
SECRETMESSAGES

输出 #1

YES
NO
YES
YES
NO

思路

题目描述有点复杂,在刚刚看这个题的时候,最开始想到的是为什么题目没有给加密方式,而是说某种.经过阅读题目输入输出,题目的加密方式可以是任何一种,则我们只需要遍历两个字符串,第二给字符串中某个字符出现的次数,在第一个字符串中有对应的次数.

代码

#include <stdio.h>
#include <string.h>
// 记录字母出现次数
int ans[26];
int test[26];
// 记录字符串
char strA[105];
char strT[105];
int main() {while (1) {// 注意初始化memset(ans, 0, sizeof(ans));memset(test, 0, sizeof(test));if (scanf("%s", strA) == EOF) {return 0;}int lenA = strlen(strA);// 求出现次数for (int k = 0; k < lenA; k++) {ans[strA[k] - 'A']++;}scanf("%s", strT);int lenT = strlen(strT);for (int m = 0; m < lenT; m++) {test[strT[m] - 'A']++;}int flag = 0;int i;for (i = 0; i < 26; i++) {flag = 0;// 等于0时代表没有出现,跳过if (test[i] == 0) {continue;}for (int j = 0; j < 26; j++) {if (test[i] == ans[j]) {// 匹配了就把ans置零ans[j] = 0;flag = 1;break;}}if (flag == 0) {printf("NO\n");break;} else {continue;}}// 等于26代表所有字母都能有匹配if (i == 26) {printf("YES\n");}}return 0;
}

紫书的答案是使用排序之后,是否能一一对应来完成判断的,简单实现了一下

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int ans[26];
int test[26];
char strA[105];
char strT[105];
// 使用<stdlib.h>中的qsort,需要自定义一个cmp函数
int cmp(const void *a, const void *b) {if (*(int *)a > *(int *)b) {return 1;} else if (*(int *)a < *(int *)b) {return -1;} else {return 0;}
}
int main() {while (1) {memset(ans, 0, sizeof(ans));memset(test, 0, sizeof(test));if (scanf("%s", strA) == EOF) {return 0;}int lenA = strlen(strA);for (int k = 0; k < lenA; k++) {ans[strA[k] - 'A']++;}scanf("%s", strT);int lenT = strlen(strT);for (int m = 0; m < lenT; m++) {test[strT[m] - 'A']++;}// qsort排序qsort(ans, 26, sizeof(int), cmp);qsort(test, 26, sizeof(int), cmp);int i;for (i = 0; i < 26; i++) {if (ans[i] != test[i]) {printf("NO\n");break;}}if (i == 26) {printf("YES\n");}}return 0;
}

UVA1339 古老的密码 Ancient Cipher 题解相关推荐

  1. UVA1339 古老的密码 Ancient Cipher 排序

    UVA1339 古老的密码 Ancient Cipher 题目描述 古罗马帝国有一个拥有各种部门的强大政府组织.其中一个部门就是保密服务部门.为了保险起见,在省与省之间传递的重要文件中的大写字母是加密 ...

  2. 例题4-1 UVA1339 古老的密码 Ancient Cipher

    输入两个串,问能不能按照一定规则映射.但是怎么映射没说,其实就是统计两个字符串各个字母出现的次数,然后分别对这两个次数序列排序,看看排完之后的两个序列是不是相同,就可以判断了, #include &l ...

  3. 《算法竞赛入门经典》 例题 4-1 古老的密码(Ancient Cipher) UVa 1339

    题目描述 给定两个长度相同且不超过100的字符串,判断是否能把其中一个字符串的各个字母重排,然后对26个字母做一个一一映射,使得两个字符串相同. 例如,JWPUDJSTVP重排后可以得到WJDUPSJ ...

  4. 例题 4-1 古老的密码(Ancient Cipher) UVa 1339

    题目:古老的密码 题目描述: 给定两个长度一样且不超过100的字符串,判断是否能把其中一个字符串的各个字母重排,之后对26个字母做一个一一映射,使得两个字符串相同 例如,JWPUDJSTVP重排后可以 ...

  5. uva1339古老的密码

    此题比较简单,主要一点就是注意字符串的元素可以交换顺序然后才映射. 注意,在排序的地方可以直接调用c语言中的qsort函数或者c++语言中的sort函数. #include <stdio.h&g ...

  6. 例题4-1 古老的密码 UVa1339

    算法竞赛入门经典(第2版)第4章 函数和递归 例题4-1 古老的密码 UVa1339 感悟. 1.阅读书中题目,对映射方式(B->A,C->B,...,Z->Y),印象深刻,马上编码 ...

  7. Ancient Cipher C++题解

    Ancient Cipher C++题解 题目 Ancient Roman empire had a strong government system with various departments ...

  8. UVa1339(古老的密码)

    UVa1339(古老的密码) 题目:古老的密码 题目描述: 给定两个长度一样且不超过100的字符串,判断是否能把其中一个字符串的各个字母重排,之后对26个字母做一个一一映射,使得两个字符串相同 例如, ...

  9. 现代密码学1.3--古典密码/historical cipher

    现代密码学1.3--古典密码/historical cipher Caesar's cipher/凯撒密码 The shift cipher/移动密码 The mono-alphabetic subs ...

最新文章

  1. C标准库stdlib.h概况
  2. Android使用Retrofit2.0和RxJava2.0处理网络请求
  3. oracle——服务器同时安装服务端和客户端冲突
  4. ASP.NET FormsAuthentication跨站点登录时绝对地址返回的问题
  5. jQuery 文档操作方法 (四)
  6. tkMessageBox only show one window
  7. 【C++后台开发面经】面试总结第七波:面试智力题
  8. KPEG123压电蜂鸣器驱动电路
  9. 天才数学家连续拿下菲尔兹奖、新视野奖,专攻“最难的简单问题”,生活中还是个社牛...
  10. jquery foreach循环
  11. 1-10000水仙花数
  12. 软件测试基础 之测试思路(笔记 重要)
  13. 【毕业设计_课程设计】手写数字识别系统的设计实现(源码+论文)
  14. python any_python的any
  15. 2DPCA—二维主成分分析详解及编程
  16. html双击变成可编辑状态,JS实现双击编辑可修改状态的方法
  17. 苹果公司的“多样化”定义:包括加拿大人
  18. asp.net是什么?
  19. 微信支付、公众号支付、微信APP支付教程
  20. [Unity] Catan Universe: Unity 的移动设备优化

热门文章

  1. ohmyzsh的安装(2020年)
  2. [zz] 电脑灵异事件
  3. foxmail登录outlook账号
  4. 我的世界java版和windows版_我的世界基岩版与Java版有什么区别?
  5. 意法半导体STM32MP157A MPU加持,米尔科技首款ST Linux开发板MYD-YA157C评测
  6. oracle怎么显示对方科目,EBS会计科目
  7. 微信视频全屏问题解决方案
  8. 阴阳师脚本开源_如何使更多的设计师开源
  9. 淮北最好吃的,不能错过的店
  10. 基于FME一键生成三调_年度变更举证图斑信息表