1、把字符数组求字符串长度、比较大小、复制和遍历字符数组操作以及标准库类型string的如何定义与初始化、读写操作(cin不能读入空格及空格之后的字符,建议读入用geline形式)、string的empty和size操作、两个string对象的相加以及遍历字符串操作,每一种操作在DEV上面自己实现一遍。
2、字符串匹配
给定两个长度相同的字符串 a 和字符串 b。
如果在某个位置 i 上,满足字符串 a 上的字符 a[i] 和字符串 b 上的字符 b[i] 相同,那么这个位置上的字符就是匹配的。
如果两个字符串的匹配位置的数量与字符串总长度的比值大于或等于 k,则称两个字符串是匹配的。
现在请你判断给定的两个字符串是否匹配。
输入格式
第一行包含一个浮点数 k,第二行包含字符串 a,第三行包含字符串 b。输入的字符串中不包含空格。
输出格式
如果两个字符串匹配,则输出 yes。否则,输出 no。
数据范围
0≤k≤1, 字符串的长度不超过 100。输入样例:
0.4
abcde
xbacd
输出样例:
no
3、循环相克令
循环相克令是一个两人玩的小游戏。
令词为“猎人、狗熊、枪”,两人同时说出令词,同时做出一个动作——猎人的动作是双手叉腰;狗熊的动作是双手搭在胸前;枪的动作是双手举起呈手枪状。
双方以此动作判定输赢,猎人赢枪、枪赢狗熊、狗熊赢猎人,动作相同则视为平局。
现在给定你一系列的动作组合,请你判断游戏结果。
输入格式
第一行包含整数 T,表示共有 T 组测试数据。接下来 T 行,每行包含两个字符串,表示一局游戏中两人做出的动作,字符串为 Hunter, Bear, Gun中的一个,这三个单词分别代表猎人,狗熊和枪。
输出格式
如果第一个玩家赢了,则输出 Player1。如果第二个玩家赢了,则输出 Player2。
如果平局,则输出 Tie。
数据范围
1≤N≤100
输入样例
3
Hunter Gun
Bear Bear
Hunter Bear
输出样例
Player1
Tie
Player2
4、替换字符
给定一个由大小写字母构成的字符串。
把该字符串中特定的字符全部用字符 # 替换。
请你输出替换后的字符串。
输入格式
输入共两行。第一行包含一个长度不超过 30 的字符串。
第二行包含一个字符,表示要替换掉的特定字符。
输出格式
输出共一行,为替换后的字符串。输入样例:
hello
l
输出样例:
he##o
5、信息加密
在传输信息的过程中,为了保证信息的安全,我们需要对原信息进行加密处理,形成加密信息,从而使得信息内容不会被监听者窃取。
现在给定一个字符串,对其进行加密处理。
加密的规则如下:
字符串中的小写字母,a 加密为 b,b 加密为 c,…,y 加密为 z,z 加密为 a。 字符串中的大写字母,A 加密为 B,B 加密为C,…,Y 加密为 Z,Z 加密为 A。 字符串中的其他字符,不作处理。
请你输出加密后的字符串。输入格式
共一行,包含一个字符串。注意字符串中可能包含空格。输出格式
输出加密后的字符串。数据范围
输入字符串的长度不超过 100。输入样例:
Hello! How are you!
输出样例:
Ifmmp! Ipx bsf zpv!
6、只出现一次的字符
给你一个只包含小写字母的字符串。
请你判断是否存在只在字符串中出现过一次的字符。
如果存在,则输出满足条件的字符中位置最靠前的那个。
如果没有,输出 no。
输入格式
共一行,包含一个由小写字母构成的字符串。数据保证字符串的长度不超过 100000。
输出格式
输出满足条件的第一个字符。如果没有,则输出 no。
输入样例:
abceabcd
输出样例:
e
7、字符串插入
有两个不包含空白字符的字符串 str 和 substr,str 的字符个数不超过 10,substr 的字符个数为3。(字符个数不包括字符串结尾处的 \0。)
将 substr 插入到 str 中 ASCII 码最大的那个字符后面,若有多个最大则只考虑第一个。
输入格式
输入包括若干行,每一行为一组测试数据,格式为str substr输出格式
对于每一组测试数据,输出插入之后的字符串。输入样例:
abcab eee
12343 555
输出样例:
abceeeab
12345553