题目:
“666”是一种网络用语,大概是表示某人很厉害、我们很佩服的意思。最近又衍生出另一个数字“9”,意思是“6翻了”,实在太厉害的意思。如果你以为这就是厉害的最高境界,那就错啦 —— 目前的最高境界是数字“27”,因为这是 3 个 “9”!
本题就请你编写程序,将那些过时的、只会用一连串“6666……6”表达仰慕的句子,翻译成最新的高级表达。
输入格式:
输入在一行中给出一句话,即一个非空字符串,由不超过 1000 个英文字母、数字和空格组成,以回车结束。
输出格式:
从左到右扫描输入的句子:如果句子中有超过 3 个连续的 6,则将这串连续的 6 替换成 9;但如果有超过 9 个连续的 6,则将这串连续的 6 替换成 27。其他内容不受影响,原样输出。
输入样例:
it is so 666 really 6666 what else can I say 6666666666
输出样例:
it is so 666 really 9 what else can I say 27
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
栈限制
8192 KB
题意解析:
输入一个字符串(注意存在空格,可以用getline完成输入),遍历字符串,遇到连续的6进行就进行判定,连续6个数大于3但是小于等于9时,就将这段连续的6整体替换为‘9’,连续6个数大于9时,则将这段连续的6整体替换为"27",完成后输出即可
AC代码:
#include<bits/stdc++.h>
using namespace std;
int main(){
string ch;
getline(cin, ch); //因为字符串含空格,所以使用getline来输入
for(int i = 0; i < ch.size(); i ++ )
if(ch[i] == '6'){//遇到6,判定连续6的数量并相应处理
int j = i + 1;//用j记录连续的6一共有多少个
while(ch[j] == '6') j ++ ; //循环向后查找
if(j - i > 3) //这里的j - i就是6的个数
if(j - i > 9) ch.replace(i, j - i, "27"); //如果6的个数大于9个,整体替换为"27"
else ch.replace(i, j - i, "9");//大于3个但是小于9个,整体替换为‘9’
}
cout << ch;//输出处理后的答案
return 0;
}