目录
题目描述
https://vj.e949.cn/9b33ac42e5fbc32e8c88307566611887?v=1541912899
题意分析
题意:给你一个字符串,让你判断它是不是回文/镜像串
AC代码
/**
* Copyright(c)
* All rights reserved.
* Author : Mingzhe
* Date : 2018-11-04-10.13.03
* Description : sample
*/
#include <cstdio>
#include <cmath>
#include <iostream>
#include <algorithm>
#include <iomanip>
#include <cstdlib>
#include <map>
#include <list>
#include <stack>
#include <queue>
#include <string>
#include <cstring>
#include <memory.h>
#define MAXN 10005
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll;
char s[100];
const char *a = "A 3 HIL JM O 2TUVWXY51SE Z 8 ";
const char *msg[] = {"not a palindrome.","a regular palindrome.", "a mirrored string.","a mirrored palindrome."};
char pend(char p){
if(isalpha(p)) return a[p-'A'];
else return a[p-'0'+25];
}
int main(){
while(scanf("%s",s)!=EOF){
int len = strlen(s),m=1,n=1;
for(int i = 0; i < (len+1)/2; i++){
if(s[i] != s[len-1-i]) m = 0; //回文判定
if(pend(s[i]) != s[len-1-i]) n = 0; //镜像判定
}
printf("%s -- is %s\n\n", s, msg[n*2+m]);
}
return 0;
}