UVa-401-Palindromes(回文)

这一题的话我们可以把映像字符的内容给放入一个字符串常量里面,然后开辟一个二维的字符串常量数组,里面放置答案。

对于回文实际上是很好求的,对于镜像的话,我们写一个返回char的函数,让它接收一个char。

接收之后进行判断,如果它是字母的话,我们就返回它减去'A'这个字母,得到的整数下标对应的镜像字符串中的字母。

如果不是,我们就返回它减去字符0,得到它的整数值,然后加上25得到它的下标,然后返回对应字母。

这题其实很简单,认真看看就行了。

#include <stdio.h>
#include <ctype.h>
#include <string.h>

const char* rev="A   3  HIL JM O   2TUVWXY51SE Z  8";
const char* msg[]={"is not a palindrome.","is a regular palindrome.",
					"is a mirrored string.","is a mirrored palindrome."};
					
char r(char ch)
{
	if (isalpha(ch))
		return rev[ch-'A'];
	else 
		return rev[ch-'0'+25];
}

int main()
{
	char s[30];
	while (scanf("%s",s)!=EOF) {
		int p=1,m=1;
		int len=strlen(s);
		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 -- %s

",s,msg[p+2*m]);
	}
	return 0;
}
原文地址:https://www.cnblogs.com/xyqxyq/p/10211332.html