旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及坏掉的那些键,打出的结果文字会是怎样?
输入格式:
输入在 2 行中分别给出坏掉的那些键、以及应该输入的文字。其中对应英文字母的坏键以大写给出;每段文字是不超过?105?个字符的串。可用的字符包括字母 [a -z ,?A -Z ]、数字?0 -9 、以及下划线?_ (代表空格)、, 、. 、- 、+ (代表上档键)。题目保证第 2 行输入的文字串非空。
注意:如果上档键坏掉了,那么大写的英文字母无法被打出。
输出格式:
在一行中输出能够被打出的结果文字。如果没有一个字符能被打出,则输出空行。
输入样例:
7+IE.
7_This_is_a_test.
结尾无空行
输出样例:
_hs_s_a_tst
分析:?
? ? ? ?1,代表上档键只有'+'
? ? ? ? 2,当第一行位空的时候,用gerchar()捕获,scanf不能捕获。
? ? ? ?3,字母大小写变换可以用<ctype.h>中的函数tolower和toupper
#include<stdio.h>
#include<string.h>
char strdown(char *str,int len){//大写字母变小的函数
int i;
for(i=0;i<len;i++){
if(*(str+i)>='A' && *(str+i)<='Z'){
*(str+i)+=32;
}
}
return *str;
}
char strup(char *str,int len){//小写字母变大的函数
int i;
for(i=0;i<len;i++){
if(*(str+i)>='a' && *(str+i)<='z'){
*(str+i)-=32;
}
}
return *str;
}
int main(){
char *one,*two,ones[100001]={NULL},twos[100001]={NULL},over[100001]={NULL};//赋初值
int i=0,k=0,swtice=0;
for(i=0;(ones[i]=getchar())!='\n';++i); ones[i]='\0';//scanf不能获得空行(\n)
scanf("%s",twos);
one=ones;//指针指向数组的第一个地址
two=twos;
*one=strdown(one,strlen(ones));
for(i=0;i<strlen(ones);i++){//判断说否有'+'
if(*(one+i)=='+'){
swtice=1;
break;
}
}
if(swtice==0){
for(i=0;i<strlen(twos);i++){
if(NULL==strchr(one,*(two+i))){
over[k++]=*(two+i);
}
}// 去掉坏键盘的小写
*one=strup(one,strlen(ones));
for(i=0;over[i]!='\0';++i){
if(NULL==strchr(one,*(over+i))){
printf("%c",*(over+i));
}
}//去掉坏键盘的大写
}
if(swtice==1){//有'+'
for(i=0;i<strlen(twos);i++){
if(NULL==strchr(one,*(two+i))){
if(*(two+i)>='A' && *(two+i)<='Z'&&swtice==1){
continue;
}
printf("%c",*(two+i));
}
}
}
return 0;
}
?这题解法运用了1029旧键盘的部分代码(5条消息) PAT 1029 旧键盘_MA_dou的博客-CSDN博客
|