zoukankan      html  css  js  c++  java
  • 回文词

    题目来自于刘汝佳的《算法竞赛入门经典(第二版)》

    题目描述:
    输入一个字符串,判断它是否为回文串以及镜像串。输入字符串保证不含数字0。所谓回文串,就是反转以后跟原串相同,如 abba 和 madam。所有镜像串,就是左右镜像之后和原串相同,如 2s 和 3AIAE。注意,并不是每个字符在镜像之后都能得到一个合法字符。在本题中,每个字符的镜像如图所示

      输入的每行包含一个字符串(保证只有上述字符,不含空白字符),判断它是否为回文串和镜像串(共四种组合)。每组数据之后输出一个空行。

      样例输入:

      NOTAPALINDROME

      ISAPALINILAPASI

      2A3MEAS

      ATOYOTA

      样例输出:
      NOTAPALINDROME -- is not a palindrome.

      ISAPALINILAPASI -- is a regular palindrome.

      2A3MEAS -- is a mirrored string.

      ATOYOTA -- is a mirrored palindrome.

    我的代码:

    #include<iostream>
    #include<cstring>
    #include<ctype.h>
    using namespace std;
    
    int main() {
        char a[100], chat[]="A   3  HIL J O   2TUVWX51SE Z  8 ";
        int i, j, note = 0, no = 0;
        while (cin >> a)
        {
            note = 0;
            for (i = 0; i < strlen(a) / 2; i++) 
            {
                if (a[i] == a[strlen(a) - 1 - i]) 
                {
                    if (isalpha(a[i]) && chat[a[i] - 65] != a[strlen(a) - 1 - i])
                    {
                        no = 1;
                        break;
                    }
                }
                if (a[i] != a[strlen(a) - 1 - i])
                {
                    if (isalpha(a[i]) && chat[a[i] - 65] != a[strlen(a) - 1 - i])
                    {
                        no = 1;
                        break;
                    }
                    note = 1;
                    break;
                }
            }
            if (note == 0 && no == 0)
            {
                cout << a << "-- is a mirrored palindrome.
    ";
                continue;
            }
            if (note == 1)
            {
                cout << a << " -- is not a palindrome.
    ";
                continue;
            }
            if (note == 0)
            {
                cout << a << " -- is a regular palindrome.
    ";
                continue;
            }
            if (no == 0)
            {
                cout << a << "-- is a mirrored string.
    ";
                continue;
            }
            if (no == 1)
            {
                cout << a << "-- is not a mirrored string.
    ";
                continue;
            }
        }
        return 0;
    }

    答案的代码:

    #include<stdio.h>
    #include<string.h>
    #include<ctype.h>
    const char* rev = "A   3  HIL J O   2TUVWX51SE Z  8 ";
    const char* msg[] = { "not a palindrome", "a regular palindrome", "a mirrored string", "a mirrored palindrome" };
    char r(char ch) {
        if (isalpha(ch)) return rev[ch - 'A'];
        return rev[ch - '0' + 25];
    }
    int main() {
        char s[30];
        while (scanf("%s", s) == 1) {
            int len = strlen(s);
            int p = 1, m = 1;
            for (int i = 0; i < (len + 1) / 2; i++) {
                if (s[i] != s[len - 1 - i])p = 0;
                if (r(s[i]) != s[len - 1 - i]) m = 0;
            }
            printf("%s -- is %s.
    
    ", s, msg[m * 2 + p]);
        }
        return 0;
    }
  • 相关阅读:
    C++ STL——list
    C++ STL——deque
    C++ STL——string和vector
    C++ STL——C++容器的共性和相关概念
    C++ STL——输入输出流
    C++ STL——异常
    C++ STL——类型转换
    C++ STL——模板
    使用PYTHON统计项目代码行数
    在Ubuntu 16.04 LTS下编译安装OpenCV 4.1.1
  • 原文地址:https://www.cnblogs.com/Breathmint/p/7220916.html
Copyright © 2011-2022 走看看