题目重现:
“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
实现思路:
-
遍历字符串:
- 遍历字符串
a
的每一个字符a[i]
。 - 如果当前字符是 '6',则
n
自增1。 - 如果当前字符不是 '6',则根据
n
的值进行相应的替换操作,并输出当前字符a[i]
,然后重置n
为0。
- 遍历字符串
-
替换操作:
- 如果
n
小于等于3,原样输出所有连续的 '6'。 - 如果
n
大于3且小于等于9,输出一个 '9'。 - 如果
n
大于9,输出 '27'。
- 如果
-
处理字符串末尾:
- 在遍历结束后,检查
n
的值,因为最后一个字符可能是 '6',需要单独处理字符串末尾的连续 '6'。 - 根据
n
的值,执行相应的替换操作
- 在遍历结束后,检查
关键代码:
if(k>0)
{
if(n<=3){
for(int j=0;j<n;j++)
cout<<"6";
}
else if(n>3&&n<=9)
cout<<"9";
else cout<<"27";
}
通过截图:
完整代码:
#include <iostream>
#include<bits/stdc++.h>
using namespace std;
int main()
{
string a;
int n=0;
getline(cin,a);
size_t k=a.size();
for(int i=0;i<k;i++)
{
if(a[i]=='6')n++;
else{
if(n<=3){
for(int j=0;j<n;j++)
cout<<"6";
}
else if(n>3&&n<=9)
cout<<"9";
else cout<<"27";
cout<<a[i];
n=0;
}
}
if(k>0)
{
if(n<=3){
for(int j=0;j<n;j++)
cout<<"6";
}
else if(n>3&&n<=9)
cout<<"9";
else cout<<"27";
}
return 0;
}