- 總時間限制:
- 1000ms
- 內存限制:
- 65536kB
- 描述
-
判斷兩個由大小寫字母和空格組成的字符串在忽略大小寫,且忽略空格后是否相等。
- 輸入
- 兩行,每行包含一個字符串。
- 輸出
- 若兩個字符串相等,輸出YES,否則輸出NO。
- 樣例輸入
-
a A bb BB ccc CCC Aa BBbb CCCccc
- 樣例輸出
-
YES
源碼如下:#include <iostream> using namespace std; bool compareTwoStringIgnoreCases(string a,string b); int main(){ char aString[30],bString[30]; cout<<"input StringA:"; cin.getline(aString,30); cout<<"input stringB:"; cin.getline(bString,30); /*aString="a A bb BB ccc CCC"; bString="Aa BBbb CCCccc";*/ if(compareTwoStringIgnoreCases(aString,bString)) cout<<"YES"; else cout<<"NO"; cout<<endl; return 0; } bool compareTwoStringIgnoreCases(string a,string b){ int i,j; for (i=0,j=0;i<a.length() && j<b.length();) { if (a[i]==b[j]||abs(a[i]-b[j])==32)//ascii碼:大寫小寫差32;空格的ascii碼對應十進制為32 { i++,j++; } else if (a[i] == 32) i++; else if (b[j] == 32) j++; else return false; } return true; }ascii碼在轉換大小寫時,有着不容忽視的力量;同時,cin標准輸入的變體也很重要:一般cin標准輸入是面相單詞進行讀取的,在這道題中,如果使用cin來讀取輸入的字符串,往往不能達到預期的效果,面相單詞是主要的阻礙,當cpu檢測到有空格輸入時,就認為是一個字符串輸入的結束,對於那些字符串中包含空格的,就是一個障礙。要解決這個問題,就用到了cin標准輸入的變體:cin.getline(char*arr,int size): 從arr開始最多讀取size個字符,但是遇到“換行符”就認為:字符串輸入結束。
這樣我們就可完成面相行的字符串讀取。
