PAT Basic 1033

1033 旧键盘打字

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

输入格式:

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

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

输出格式:

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

输入样例:

7+IE.
7_This_is_a_test.

输出样例:

_hs_s_a_tst    题解:这道题目和旧键盘那道题非常相似,都需要标记坏键,前文中有说过,标记坏键可以用map,set或是自己写一个哈希方法来标记坏键,这道题我用哈希方法具体给大家展示。   读入两个字符串后,记录下坏键的位置,输出时,若为坏键不输出即可。

代码如下:
 1 #include<iostream>
 2 #include<string>
 3
 4 using namespace std;
 5
 6 int main()
 7 {
 8     bool a[256] = {false};
 9     string ac, b;
10     bool flag = false;
11     getline(cin,ac);
12     getline(cin,b);
13     for( int i = 0; i < ac.length(); i++){
14         a[toupper(ac[i])] = true;
15         if( ac[i] == ‘+‘)
16             flag = true;
17     }
18     for( int i = 0; i < b.length(); i++){
19         if( !flag ){
20             if(!a[toupper(b[i])]) {
21                 cout<<b[i];
22             }
23         }
24         else{
25             if( b[i] >= ‘A‘ && b[i] <=‘Z‘)
26                 continue;
27             if(!a[toupper(b[i])]){
28                 cout<<b[i];
29             }
30         }
31     }
32     return 0;
33 }

原文地址:https://www.cnblogs.com/yxp400/p/9457815.html

时间: 2024-08-07 22:09:39

PAT Basic 1033的相关文章

PAT (Basic Level) Practise (中文) 1005

1005. 继续(3n+1)猜想 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证的时候,我们需要计算3.5.8.4.2.1,则当我们对n=5.8.4.2进行验证的时候,就可以直接判定卡拉兹猜想的真伪,而不需要重

PAT (Basic Level) Practise (中文)1004. 成绩排名 (20)

读入n名学生的姓名.学号.成绩,分别输出成绩最高和成绩最低学生的姓名和学号. 输入格式:每个测试输入包含1个测试用例,格式为 第1行:正整数n 第2行:第1个学生的姓名 学号 成绩 第3行:第2个学生的姓名 学号 成绩 ... ... ... 第n+1行:第n个学生的姓名 学号 成绩 其中姓名和学号均为不超过10个字符的字符串,成绩为0到100之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的. 输出格式:对每个测试用例输出2行,第1行是成绩最高学生的姓名和学号,第2行是成绩最低

PAT乙级1033

题目链接 https://pintia.cn/problem-sets/994805260223102976/problems/994805288530460672 题解 刚开始没有理解到,如果上档键坏的话,所有大写字母都不行(My bad),后来改代码思路就很乱,甚至还考虑过_和+是否输出之类的--所以理解题意很重要吧.这个题弄得我脑袋很累. 考虑到上档键坏的话,所有大写字母都不行之后,还是会有一个测试点不过. 另外有个坑是第一行可能是空行,即所有键都是可以使用的. // PAT BasicL

PAT Basic 1057 数零壹 (20 分)

给定一串长度不超过 1 的字符串,本题要求你将其中所有英文字母的序号(字母 a-z 对应序号 1-26,不分大小写)相加,得到整数 N,然后再分析一下 N 的二进制表示中有多少 0.多少 1.例如给定字符串 PAT (Basic),其字母序号之和为:16+1+20+2+1+19+9+3=71,而 71 的二进制是 1000111,即有 3 个 0.4 个 1. 输入格式: 输入在一行中给出长度不超过 1.以回车结束的字符串. 输出格式: 在一行中先后输出 0 的个数和 1 的个数,其间以空格分隔

PAT (Basic Level) Practise:1033. 旧键盘打字

[题目链接] 旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及坏掉的那些键,打出的结果文字会是怎样? 输入格式: 输入在2行中分别给出坏掉的那些键.以及应该输入的文字.其中对应英文字母的坏键以大写给出:每段文字是不超过105个字符的串.可用的字符包括字母[a-z, A-Z].数字0-9.以及下划线“_”(代表空格).“,”.“.”.“-”.“+”(代表上档键).题目保证第2行输入的文字串非空. 注意:如果上档键坏掉了,那么大写的英文字母无法被打出

PAT Basic Level 1033

AC代码 1 #include <stdio.h> 2 #include <string.h> 3 int main () 4 { 5 int completetrue = 0; //1代表有错 6 int upperlock = 0; //1代表大写无法输出 7 char faultkey[100]; 8 char input[100000]; 9 gets(faultkey); 10 scanf("%s",&input); 11 int length

PAT (Basic Level) Practise 1040 有几个PAT(DP)

1040. 有几个PAT(25) 时间限制 120 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 字符串APPAPT中包含了两个单词“PAT”,其中第一个PAT是第2位(P),第4位(A),第6位(T):第二个PAT是第3位(P),第4位(A),第6位(T). 现给定字符串,问一共可以形成多少个PAT? 输入格式: 输入只有一行,包含一个字符串,长度不超过105,只包含P.A.T三种字母. 输出格式: 在一行中输出给定字符串中

PAT (Basic Level) Practise 1003. 我要通过!

1003. 我要通过! 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue “答案正确”是自动判题系统给出的最令人欢喜的回复.本题属于PAT的“答案正确”大派送 —— 只要读入的字符串满足下列条件,系统就输出“答案正确”,否则输出“答案错误”. 得到“答案正确”的条件是: 1. 字符串中必须仅有P, A, T这三种字符,不可以包含其它字符:2. 任意形如 xPATx 的字符串都可以获得“答案正确”,其中 x 或者是

PAT (Basic Level) Practise:1040. 有几个PAT

[题目链接] 字符串APPAPT中包含了两个单词“PAT”,其中第一个PAT是第2位(P),第4位(A),第6位(T):第二个PAT是第3位(P),第4位(A),第6位(T). 现给定字符串,问一共可以形成多少个PAT? 输入格式: 输入只有一行,包含一个字符串,长度不超过105,只包含P.A.T三种字母. 输出格式: 在一行中输出给定字符串中包含多少个PAT.由于结果可能比较大,只输出对1000000007取余数的结果. 输入样例: APPAPT 输出样例: 2 提交代码: 1 #includ