• UVA1339 UVALive3213 POJ2159 ZOJ2658 Ancient Cipher【密码】


    Regionals 2004 >> Europe - Northeastern


    问题链接UVA1339 UVALive3213 POJ2159 ZOJ2658 Ancient Cipher基础训练题,用C语言编写程序。

    问题分析:对两组字符串分别进行字母统计,接着对统计结果进行排序,然后对排序后的结果进行比较。如果相同,说明可以找到一种一一映射,使得两个字符串相同。

    程序说明:比较两组非字符值是否相等,还可以使用函数memcmp()来实现,参考相关链接。


    AC的C语言程序如下:

    /* UVA1339 UVALive3213 POJ2159 ZOJ2658 Ancient Cipher */
    
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <memory.h>
    
    #define LETTERNUM 26
    #define MAXN     100
    
    int cmp(const void * a, const void * b)
    {
        return *(int *)a - *(int *)b;
    }
    
    int main(void)
    {
        char s[MAXN+1], t[MAXN+1];
        int counts[LETTERNUM], countt[LETTERNUM], len, flag, i;
    
        while(scanf("%s", s) != EOF) {
            scanf("%s", t);
    
            memset(counts, 0, sizeof(counts));
            memset(countt, 0, sizeof(countt));
    
            len = strlen(s);
            for(i=0; i<len; i++) {
                counts[s[i]-'A']++;
                countt[t[i]-'A']++;
            }
    
            qsort(counts, LETTERNUM, sizeof(counts[0]), cmp);
            qsort(countt, LETTERNUM, sizeof(countt[0]), cmp);
    
            flag = 1;
            for(i=0; i<LETTERNUM; i++)
                if(counts[i] != countt[i]) {
                    flag = 0;
                    break;
                }
    
            printf("%s
    ", flag ? "YES" : "NO");
        }
    
        return 0;
    }


    相关链接:Ancient Cipher


  • 相关阅读:
    反射和内置方法重写
    封装
    接口与抽象类 、多态
    面向对象--继承和组合
    python对象
    模块导入
    python序列化模块
    time random sys os 模块
    python re模块和collections
    python各种推导式
  • 原文地址:https://www.cnblogs.com/tigerisland/p/7564505.html
Copyright © 2020-2023  润新知