天天看点

6翻了

本题就请你编写程序,将那些过时的、只会用一连串“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

这道题的价值:

  1. 采用num计数,来统计6的长度。(我试过字符串的int index1 = str.find_first_of(‘6’);和int index2 = str.find_first_not_of(‘6’),来计算6的长度 len = index2-index1;但是这个超时了。)
  2. 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;
}