“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
Java版-正则表达式 -最简单
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
String str = scanner.nextLine();
//将超过 9 个连续的 6,则将这串连续的 6 替换成 27
str = str.replaceAll("6{10,}", "27");
//将超过 3 个连续的 6,则将这串连续的 6 替换成 27
str = str.replaceAll("6{4,}","9");
//其余正常输出
System.out.println(str);
}
}
C++版 - 记录字符串各处连续出现的6的个数,根据实际输出
#include<iostream>
#include<string>
using namespace std;
int main()
{
string str;
getline(cin, str);
int cnt = 0; //出现6的个数
for (int i = 0; i <= str.length(); i++)
{
if (str[i]=='6')//记录连续出现的 6
{
cnt++;
}
else
{
//连续出现的 6 的个数超过9 , 替换成 27 输出
if (cnt>9)
{
cout << 27;
}
else if (cnt>3)//连续出现的 6 的个数超过3 , 替换成 9 输出
{
cout << 9;
}
else
{
//其余情况 连续出现的 6 的个数小于3 有多少6照常输出
for (int i = 0; i < cnt; i++)
{
cout << 6;
}
}
cnt = 0;//重新记录连续出现 6 的个数
cout << str[i]; //非 6 的字符不受影响 正常输出
}
}
return 0;
}