“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
这个题我首先想到的是正则表达式,代码很简单,在method1里。顺便花了几分钟写了常规的解,有点臃肿不想优化了,测试点的小坑在于超过这个字眼上。
#include <iostream>
#include <string>
#include <regex>
using namespace std;
int main()
{
// method 1
/* string str;
getline(cin, str);
regex r1("6{4,9}");
regex r2("6{10,}");
str = regex_replace(str, r2, "27");
cout << regex_replace(str, r1, "9") << endl; */
// method 2
string str;
getline(cin, str);
int num = 0;
bool flag = true;
for (size_t i = 0; i < str.size(); ++i)
{
if (str[i] == '6')
{
if (!flag)
{
flag = true;
num++;
}
else
{
num++;
}
if (i == str.size() - 1)
{
if (num > 3 && num <= 9)
{
cout << "9";
}
else if (num > 9)
{
cout << "27";
}
else
{
for (int j = 0; j < num; ++j)
cout << "6";
}
}
}
else
{
if (num > 3 && num <= 9)
{
cout << "9" << str[i];
}
else if (num > 9)
{
cout << "27" << str[i];
}
else
{
for (int j = 0; j < num; ++j)
cout << "6";
cout << str[i];
}
flag = false;
num = 0;
}
}
cout << endl;
system("pause");
return 0;
}