本题就请你编写程序,将那些过时的、只会用一连串“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
这道题的价值:
- 采用num计数,来统计6的长度。(我试过字符串的int index1 = str.find_first_of(‘6’);和int index2 = str.find_first_not_of(‘6’),来计算6的长度 len = index2-index1;但是这个超时了。)
- for循环这么写的
for(int i =0;i<=len;++i)
,注意是<=len
,多一次循环,成功的避免了在循环外检查str[str.length()-1]=='6’的问题,不然还要在for循环外继续输出。
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
int main()
{
string a;
getline(cin,a);
int len = a.size();
int num=0;
for(int i = 0 ; i <= len ; i ++)
{
if(a[i]=='6'){
num++;//如果说有6这个字符,个数就加一
}else
{
if(num>9) printf("27");
else if(num>3) printf("9");
else while(num--) printf("6");
if(i==len) break;
num=0;
printf("%c",a[i]);//其他的情况就按照原格式输出,容易漏,一定记得加上
}
}
return 0;
}