“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
第一次做是想着第一次遇到6时候标记并记录下标,当标记存在且第一次不是6时候记录第二个下标,同时记录6的个数,之后循环替换。但是没接着两次出现超过九个6的情况第二次就不会输出27,没找到问题,仅记录:
#include <iostream>
#include <cmath>
#include <cstring>
#include <algorithm>
using namespace std;
int main() {
char s[1000];
int f1=0,f2=0,sum=0,j1=0,j2=0;
cin.getline(s,1000);
for(int i=0;i<strlen(s);i++){
if(s[i]=='6'){
if(f1==0){j1=i;}
f1=1;sum++;
}
if((f1==1&&s[i]!='6')||(f1==1&&i==strlen(s)-1)){
f2=1;j2=i;
}
if(f1==1&&f2==1){
if(sum>3&&sum<=9){
s[j1]='9';
for(int k=j1+1;k<strlen(s)+sum;k++){
s[k]=s[j2++];
}
j1=0;j2=0;
}
else if(sum>9){
s[j1]='2';
s[j1+1]='7';
for(int k=j1+2;k<strlen(s)+sum;k++){
s[k]=s[k+sum-2];
}
j1=0;j2=0;
}
sum=0;
f1=0;f2=0;
}
}
cout<<s;
}
只好每次判断完直接输出了,不修改字符串。。。
#include <iostream>
#include <cmath>
#include <cstring>
#include <algorithm>
using namespace std;
int main() {
char s[1001];
int f1=0,sum=0;
cin.getline(s,1001);
for(int i=0;i<strlen(s);i++){
if(s[i]=='6'){
if(f1==0)
f1=1;sum++;
}
if(f1==1&&s[i]!='6') {
if (sum > 9)cout << "27";
else if (sum > 3 && sum <= 9) { cout << "9"; }
else for (int k = 0; k < sum; k++) { cout << "6"; }
f1=0;
sum=0;
}
if(s[i]!='6'){cout<<s[i];}
}
if(sum<=3){
for(int j=0;j<sum;j++)
cout<<"6";
}else if(sum>3 && sum<=9){
cout<<"9";
}else if(sum>9){
cout<<"27";
}
}