1. 程式人生 > >回文詞(Palindromes, UVa401)

回文詞(Palindromes, UVa401)

表示 red har names yota tap sca can nbsp

輸入一個字符串,判斷它是否為回文串以及鏡像串。輸入字符串保證不含數字0。

所謂 回文串,就是反轉以後和原串相同,如abba和madam。

所謂鏡像串,就是左右鏡像之後和原串相同,如2S和3AIAE。

註意,並不是每個字符在鏡像之後都能得到一個合法字符。在本題中,每個字符的鏡像如圖所示(空白項表示該字符鏡像後不能得到一個合法字符)。

技術分享圖片

輸入的每行包含一個字符串(保證只有上述字符。不含空白字符),判斷它是否為回文 串和鏡像串(共4種組合)。每組數據之後輸出一個空行。

樣例輸入:

NOTAPALINDROME

ISAPALINILAPASI

2A3MEAS

ATOYOTA

樣例輸出:

NOTAPALINDROME -- is not a palindrome.

ISAPALINILAPASI -- is a regular palindrome.

2A3MEAS -- is a mirrored string.

ATOYOTA -- is a mirrored palindrome.

【分析】

既然不包含空白字符,可以安全地使用scanf進行輸入。回文串和鏡像串的判斷都不復雜,並且可以一起完成,詳見下面的代碼。使用常量數組,只用少量代碼即可解決這個看上去有些復雜的題目。

#include<cstdio>
#include
<cstring> #include<ctype.h> using namespace std; char rev[]="A 3 HIL JM O 2TUVWXY51SE Z 8 "; char *msg[]={"is not a palindrome","is a regular palindrome","is a mirrored string","is a mirrored palindrome"} ; char aa(char a){ if(isalpha(a)) return rev[a-A]; else return
rev[a-0+25]; } int main(){ char s[1000]; while(scanf("%s",s)==1){ 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(aa(s[i])!=s[len-1-i]) m=0;//不是鏡像串 } printf("%s--%s.\n",s,msg[m*2+p]); } return 0; }

頭文件ctype.h中定義的isalpha、isdigit、isprint等工具可以用來判斷字符 的屬性,而toupper、tolower等工具可以用來轉換大小寫。如果ch是大寫字母,則ch-‘A‘就是 它在字母表中的序號(A的序號是0,B的序號是1,依此類推);類似地,如果ch是數字, 則ch-‘0‘就是這個數字的數值本身。

回文詞(Palindromes, UVa401)