回文語(Palindromes,UVa 401)(C++)


文字列を入力して、文字列がエコー列であるかどうか、およびミラー列であるかどうかを判断します.入力された文字列には0は含まれません.回文列とは,反転後abbaやmadamのように元の列と同じである.
#include
#include
using namespace std;
char qq[]="A   3  HIL JM O   2TUVWXY51SE Z  8 ";
const char *end[4]={"        !","       !","       !","         !"}; 
char judge(char a)
{
	if(isalpha(a))
	{
		return qq[a-'A'];
	}
	else
		return qq[a-'0'+25];
}
int main()
{
	int q,m;
	char a[200];
	while(cin>>a)
	{
		q=1;//         
		m=1;//         
		int len=strlen(a);
		for(int i=0;i<len/2;i++)
		{
			if(judge(a[i])!=a[len-i-1])
			m=0;
			if(a[i]!=a[len-i-1])
			q=0;
			if(m==0&&q==0)
			break;
		}
		cout<<end[m+q*2]<<endl;//        ,      if            
		
	}
	return 0;
}