回文語(Palindromes,UVa 401)(C++)
6869 ワード
文字列を入力して、文字列がエコー列であるかどうか、およびミラー列であるかどうかを判断します.入力された文字列には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;
}