PAT 乙 1033 旧键盘打字 (测试点5过3,2错误)

探讨如何在部分按键损坏的旧键盘上输入文字,通过编程算法筛选出可输入的字符,实现特殊条件下的文本输入模拟。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1033 旧键盘打字 (20 分)

旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及坏掉的那些键,打出的结果文字会是怎样?

输入格式:

输入在 2 行中分别给出坏掉的那些键、以及应该输入的文字。其中对应英文字母的坏键以大写给出;每段文字是不超过 10​5​​ 个字符的串。可用的字符包括字母 [a-z, A-Z]、数字 0-9、以及下划线 _(代表空格)、,.-+(代表上档键)。题目保证第 2 行输入的文字串非空。

注意:如果上档键坏掉了,那么大写的英文字母无法被打出。

输出格式:

在一行中输出能够被打出的结果文字。如果没有一个字符能被打出,则输出空行。

输入样例:

7+IE.
7_This_is_a_test.

输出样例:

_hs_s_a_tst

总结:用GETS一直在C++包错,此题注意隐含情况输入1可以为空

#include<stdio.h>
//#include<string>
#include<string.h>
//using namespace std;
int count=0;
int main()
{char a1[90],a2[100000];
   gets(a1);
   gets(&a2[0]);
//scanf("%s",a2);
  // printf("%s\n",a2);
 // scanf("%s%s",a1,a2);//a1坏掉的键 
 int len1,len2,indux[67];//A-Z  0~25
   memset(indux,0,66*sizeof(int));
   len1=strlen(a1);        //a-z 26~51 
 len2=strlen(a2);        //0-9 52~61
                         // _   62
                        //,    63
                        //.    64
                        //-    65
                        //+    66 上档键 
for(int i=0;i<len1;i++)
   if(a1[i]<='Z'&&a1[i]>='A')
   {indux[a1[i]-'A']=1;//大写标记为1为坏 
    indux[a1[i]-'A'+26]=1;//小写标记为1为坏 
     }
//   else if(a1[i]<='z'&&a1[i]>='a')
//   indux[a1[i]-'a'+26]=1;//标记为1为坏
   else if(a1[i]<='9'&&a1[i]>='0') 
   indux[a1[i]-'0'+52]=1;//标记为1为坏
   else if(a1[i]=='_')
   indux[62]=1;//标记为1为坏
   else if(a1[i]==',')
   indux[63]=1;//标记为1为坏
   else if(a1[i]=='.')
   indux[64]=1;//标记为1为坏
   else if(a1[i]=='-')
   indux[65]=1;//标记为1为坏
    else if(a1[i]=='+')
   {indux[66]=1;//标记为1为坏
    for(int j=0;j<=25;j++)
    indux[j]=1;
	} 
//for(int i=0;i<67;i++)
//{cout<<indux[i]<<" ";
//if(i==25||i==51||i==61)
//cout<<endl;
//	}	

for(int i=0;i<len2;i++)
    if(a2[i]<='Z'&&a2[i]>='A'&&indux[a2[i]-'A']==0)
	{printf("%c",a2[i]+32);
	count++;
	}
    else  if(a2[i]<='z'&&a2[i]>='a'&&indux[a2[i]-'a'+26]==0)
    //cout<<a2[i]-32;
	{printf("%c",a2[i]);count++;
	}
    else if(a2[i]<='9'&&a2[i]>='0'&&indux[a2[i]-'0'+52]==0)
    {printf("%c",a2[i]);count++;
	}
    else if(a2[i]=='_'&&indux[62]==0)
    {printf("%c",a2[i]);count++;
	}
    else if(a2[i]==','&&indux[63]==0)
    {printf("%c",a2[i]);count++;
	}
     else if(a2[i]=='.'&&indux[64]==0)
    {printf("%c",a2[i]);count++;
	}
    else if(a2[i]=='-'&&indux[65]==0)
    {printf("%c",a2[i]);count++;
	}
    else if(a2[i]=='+'&&indux[66]==0)
    {printf("%c",a2[i]); count++; 
	}
	if(count==0)
	printf("\n");
    return 0;
}

 

### 关于PAT级1119题目的解析 对于PAT级中的题目1119,虽然具体的题目描述未直接给出[^1],但从常见的PAT级题目特点以及相似类型的编程挑战来看,解答此题的关键在于理解输入输出的要求、边界条件处理及算法效率。 #### 测试点3和5的关注重点 针对测试点3和5: - **大范围数据处理**:当面对较大的输入规模时,程序应能高效运行而不超时。这通常意味着需要优化时间复杂度,避免不必要的重复计算或冗余操作。 - **特殊情况考虑**:某些特定情况下(如极端最小值或最大值),标准逻辑可能无法正常工作。因此,在编写代码前应当充分思考可能出现的各种边缘情况并加以应对。 #### 编程实现建议 为了满足上述两点要求,可以采取如下措施来提高解决方案的质量: - 使用合适的数据结构存储中间结果,比如字典(dict)用于快速查找;列表(list)适合顺序访问等场景。 - 对输入参数做预处理,提前排除不符合预期的情况,减少后续流程中的判断分支数量。 - 尽量采用内置函数完成基本运算任务,因为这些经过高度优化后的库函数往往具有更好的性能表现。 ```python def solve_problem(input_data): processed_input = preprocess(input_data) result = [] # 主体业务逻辑 return postprocess(result) if __name__ == "__main__": input_value = get_user_input() output_result = solve_problem(input_value) print(output_result) ``` 考虑到不同版本之间可能存在差异,具体到本题还需要参阅官方文档或者社区讨论获取最准确的信息[^2]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值