题目描述:
“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
代码:
第一次尝试,没有ac,只得了14分,但是尝试了很多特殊情况还是找不出bug;
思路就是先扫描,再截取,再删除,最后在拼接起来,用到了,substr()和erase()方法;注意输入的方式,用cin()输入是无法正常读入的,因为有空格,所以采用getline()进行输入
#include <bits/stdc++.h>
using namespace std;
int main(){
string str;
getline(cin,str);
// cout<<str<<endl;
//思路就是扫描,截取,删除,拼接
int cnt = 0;
int start=0,end=0;
bool isStart = false;
int flag = 0;
int i=0;
for( ;i<=str.size();i++){
if(str[i]=='6'&&str[i+1]=='6'
||str[i]=='6'&&str[i+1]!='6'){
if(!isStart){
isStart = true;
start = i;
}
cnt++;
end = i+1;
}else{
if(cnt<=3){
//小于3的不用动
;
}else if(cnt>3&&cnt<=9){
//截取
string temp = str.substr(start,str.size()-start);
temp.erase(0,cnt);
str.erase(start,str.size()-start);
str+='9';
str+=temp;
}else if(cnt>9){
//和上面一样的操作
string temp = str.substr(start,str.size()-start);
temp.erase(0,cnt);
str.erase(start,str.size()-start);
str+="27";
str+=temp;
}
//更新每次截取的状态
isStart = false;
cnt = 0;
}
}
cout<<str;
}
AC代码:
第二次尝试:借鉴网上的方法:
思路就是如果不是6就逐个输出,如果是就先数有几个6,分情况进行输出
#include <bits/stdc++.h>
using namespace std;
string str;
int main(){
getline(cin,str);
int i,j;
for(i=0;i<str.size();){
if(str[i]!='6'){
cout<<str[i];
i++;
}else{
j=i;
while(str[j]=='6'){
j++;
}
if(j-i>9) cout<<"27";
else if(j-i>3) cout<<"9";
else{
for(;i<j;i++){
cout<<"6";
}
}
i = j;//继续往下进行
}
}
}
学艺不精,欢迎大家的批评指正!