Day 004:PAT练习--1033 旧键盘打字 (20 分)
题目要求如下:

我一开始理解的题意:第一行给出的是坏掉的键,这里的规则应该是这样的:
1.“对应英文字母的坏键以大写给出”,若有字母,则与其相关的字母全部不能输出,不论是大写还是小写;
2.若出现“,”“.”“-”,则不能输出这三样(注意这里的逗号是全角或者是半角,为了防止出错最好直接复制到程序中)
3.若出现“+”,则不能输出大写字母,但是不影响“+”本身的输出
4.若出现“_”,则不能输出空格(即“ ”)
这道题我们可以使用哈希表来做,使用getline来快速读取两个字符串,根据第一个字符串的内容,分别对128个ASCII码的哈希表其中涉及到的码赋正值,然后根据哈希表的值输出第二行;若没有能输出的字符,则输出换行。
这样编写完程序之后,发现无论如何调整都有一个得分点无法通过,经我的npy和zju群里的兄弟指点之后发现了错误所在:
前面的第四条,题目中说的是

因此这两个串中是不会出现真正的空格的,而是以下划线本身代替,即下划线就是空格的化身(az)。
调整后完全正确的程序如下所示:
#include<bits/stdc++.h>
using namespace std;
bool HashTable[256] = {false};
int main(){
string s1, s2;
getline(cin, s1);
getline(cin, s2);
int len1 = s1.length(), len2 = s2.length();
int flag = 0;
for(int i = 0; i < len1; i++){
if(s1[i] == '+'){
for(int j = 65; j <= 90; j++){
HashTable[j] = true;
}
//HashTable[43] = true;//这是我误以为不能输出+的地方
}else if(s1[i] == '_'){
//HashTable[32] = true;//这里就是我写错的地方
HashTable[95] = true;
}else if(s1[i] >= 65 && s1[i] <= 90){
HashTable[s1[i] + 32] = true;
HashTable[s1[i]] = true;
}else{
HashTable[s1[i]] = true;
}
}
for(int i = 0; i < len2; i++){
if(HashTable[s2[i]] == false){
printf("%c", s2[i]);
flag++;
}
}
if(flag == 0){
printf("\n");
}
return 0;
}
为表示感谢,再次贴上zju群里阿萨姆同学的代码,他的要简洁一些:
#include<iostream>
#include<cstring>
using namespace std;
int hashT[130];//防止不必要的溢出错误
int main()
{
string a,b;
getline(cin,a);
getline(cin,b);
for(int i=0;i<a.length();i++){
hashT[(int)a[i]]=1;
if(a[i]>='A'&&a[i]<='Z')hashT[(int)a[i]+32]=1;
if(a[i]=='+')memset(hashT+65,1,26*sizeof(int));//使用memset更快一点
}
for(int i=0;i<b.length();i++)if(!hashT[(int)b[i]])cout<<b[i];
cout<<endl;
return 0;
}
最后给大家推荐一个方便别人修改你的代码的网站:
https://paste.ubuntu.com/
使用方法如下:

大家明天见!
Day 004:PAT练习--1033 旧键盘打字 (20 分)的更多相关文章
- PAT Basic 1033 旧键盘打字 (20 分)
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及坏掉的那些键,打出的结果文字会是怎样? 输入格式: 输入在 2 行中分别给出坏掉的那些键.以及应该输入 ...
- PAT乙级 1033. 旧键盘打字(20)
1033. 旧键盘打字(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 旧键盘上坏了几个键,于是在敲一段文 ...
- PAT (Basic Level) Practice (中文)1033 旧键盘打字 (20 分)
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及坏掉的那些键,打出的结果文字会是怎样? 输入格式: 输入在 2 行中分别给出坏掉的那些键.以及应该输入 ...
- 1033 旧键盘打字 (20 分)C语言
题目描述 旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及坏掉的那些键,打出的结果文字会是怎样? 输入描述: 输入在2行中分别给出坏掉的那些键.以及应 ...
- PAT1033 旧键盘打字 (20分) (关于测试点4超时问题)
1033 旧键盘打字 (20分) 旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及坏掉的那些键,打出的结果文字会是怎样? 输入格式: 输入在 2 ...
- PAT (Basic Level) Practise (中文)-1033. 旧键盘打字(20)
PAT (Basic Level) Practise (中文)-1033. 旧键盘打字(20) http://www.patest.cn/contests/pat-b-practise/1033 旧 ...
- PAT 1033 旧键盘打字(20)(20 分)
1033 旧键盘打字(20)(20 分) 旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及坏掉的那些键,打出的结果文字会是怎样? 输入格式: 输入在2 ...
- PAT(B) 1033 旧键盘打字(C) 字符
题目链接:1033 旧键盘打字 (20 point(s)) 题目描述 旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及坏掉的那些键,打出的结果文字会是 ...
- PAT-乙级-1033. 旧键盘打字(20)
1033. 旧键盘打字(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 旧键盘上坏了几个键,于是在敲一段文 ...
随机推荐
- 从HDFS的写入和读取中,我发现了点东西
摘要:从HDFS的写入和读取中,我们能学习到什么? 本文分享自华为云社区<从HDFS的写入和读取中,我们能学习到什么>,作者: breakDawn . 最近开发过程涉及了一些和文件读取有关 ...
- 西门子S7-1200PLC不让下载一直报“模块具有激活的测试和调试功能,防止下载到设备”解决方法
错误如图 这是因为PLC被强制了,导致下载会报这类错误.取消强制就可以下载. 或者将cpu重置为出厂设置,也能再次下载. 参考:https://www.ad.siemens.com.cn/servic ...
- luogu4883 mzf的考验
题目描述: luogu 题解: 当然splay. 区间翻转是基本操作. 区间异或?按套路记录区间内每一位$1$的个数,异或的时候按位取反即可. 区间查询同理. 因为要按位维护,所以复杂度多了个log. ...
- spring学习二:jdbc相关回顾以及spring下dao
目录: Part一:回顾java web部分的jdbc.事务.连接池和dbutils工具等 : Part二:spring的JdbcTemplate使用: Part三:spring的事务处理: Part ...
- 简述在 MySQL 数据库中 MyISAM 和 InnoDB 的区别 ?
MyISAM: 第 134 页 共 485 页不支持事务,但是每次查询都是原子的: 支持表级锁,即每次操作是对整个表加锁: 存储表的总行数: 一个 MYISAM 表有三个文件:索引文件.表结构文件.数 ...
- Java 中的 final 关键字有哪些用法?
修饰类:表示该类不能被继承: 修饰方法:表示方法不能被重写: 修饰变量:表示变量只能一次赋值以后值不能被修改(常量).
- 学习SVN01
SVN服务器搭建实录 第一章 SVN介绍 1.1 什么是SVN(subversion) SVN是近年来崛起的非常优秀的版本管理工具,与CVS管理工具一样,SVN是一个固态的跨平台的开源的版本控制 ...
- 面试题目:手写一个LRU算法实现
一.常见的内存淘汰算法 FIFO 先进先出 在这种淘汰算法中,先进⼊缓存的会先被淘汰 命中率很低 LRU Least recently used,最近最少使⽤get 根据数据的历史访问记录来进⾏淘汰 ...
- c++中的赋值函数
在c++中,对于任意一个类Class A,如果程序员不显示的声明和定义上述函数,C++编译器将会自动的为A产生4个public inline 的默认函数,这4个函数最常见的形式为: A() //默认构 ...
- Android.mk文件如何打日志信息
1. 在mk文件中添加:$(warning "xxx="$(变量名)) 2. 执行lunch,选一个分支,此过程中可以打出添加的log.