PTA 1029 舊鍵盤
阿新 • • 發佈:2019-02-15
題目連結
思路:定義三個字元陣列,一個用來表示輸入文字(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;
}