1. 程式人生 > >PTA 1029 舊鍵盤

PTA 1029 舊鍵盤

題目連結
思路:定義三個字元陣列,一個用來表示輸入文字(str1),一個用來表示實際的輸入文字(str2),一個用來儲存壞掉的鍵(s)。然後,逐個比較str1與str2中的字元,若兩者字元相同,則繼續比較;若不同,則將str1中的此位置字元儲存到s中,並讓str1當前所處位置往後移動,且s的長度加1。隨後,對s中所有字元進行判斷,首先,將小寫字母轉化為大寫字母,其次,若重複出現,則不輸出;反之,若不重複出現則輸出。
AC程式碼:

#include<iostream>
#include<cstring>
#include<cctype>
using namespace
std; int main() { char str1[81],str2[81],s[81]; cin>>str1; cin>>str2; int len1,len2,i=0,j=0,len3=0; len1=strlen(str1); len2=strlen(str2); while(i<len1) { if(str1[i]==str2[j]) { i++; j++; } else { s[len3]=str1[i]; len3++; i++; } } for
(int k=0;k<len3;k++) { int flag=0; if(islower(s[k])) { s[k]=s[k]-32; } for(int l=0;l<k;l++) { if(s[l]==s[k]) { flag=1; break; } } if(flag==0) cout
<<s[k]; } cout<<endl; return 0; }