题目重现:
“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
定义一个字符串变量a1用于存储输入。定义一个字符串变量a2用于存储处理后的结果。
定义一个整型变量 count 并初始化为0,用于计数连续的 ‘6’。
如果当前字符是 ‘6’,则将 cont 加1。如果当前字符不是 ‘6’,则根据 count 的值处理之前累计的 ‘6’;如果 count 大于9,则将 “27” 追加到 a2。如果 count 大于3但不超过9,则将 “9” 追加到 a2。如果 count 不超过3,则将 count 个 ‘6’ 追加到 a2。将当前非 ‘6’ 字符追加到 a2。重置 a2 为0。 在遍历完 a1 后,检查 count 的值,并按照上述规则处理末尾的连续 ‘6’。
#include <iostream>
#include <string>
using namespace std;
int main() {
string a1, a2;
int cont = 0;
getline(cin, a1);
for (char ch : a1)
{
if (ch == '6')
{
cont++;
}
else
{
if (cont > 0)
{
if (cont > 9)
a2 += "27";
else if (cont > 3)
a2 += '9';
else if(cont==3)
a2 += "666";
else if(cont==2)
a2 += "66";
else
a2+='6';
cont = 0;
}
a2 += ch;
}
}
// 处理字符串末尾可能存在的连续6
if (cont > 0)
{
if (cont > 9)
a2 += "27";
else if (cont > 3)
a2 += '9';
else if (cont > 3)
a2 += '9';
else if(cont==3)
a2 += "666";
else if(cont==2)
a2 += "66";
else
a2+='6';
}
cout<<a2<<endl;
return 0;
}
这道题需要想好所有情况的可能,并不需要用到很高级的工具实现,简单的字符串就可以实现代码。