回文詞(Palindromes, UVa401)
阿新 • • 發佈:2019-02-09
表示 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 returnrev[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)