本題就請你編寫程式,将那些過時的、隻會用一連串“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)
,多一次循環,成功的避免了在循環外檢查str[str.length()-1]=='6’的問題,不然還要在for循環外繼續輸出。<=len
#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;
}