“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的长度,根据长度进行替换,这样就行了,但是这样提交之后测试点5是错的,后来想了想可能不是单词的形式给出的。
14分代码:
#include<stdio.h>
#include<string.h>
int main(){
char s[1000][100];//s用来统计每一个单词
char ch;
int num=0;
int count=0;
while((ch=getchar())!='\n'){//将字符以单词的形式保存
if(ch!=' '){
s[num][count]=ch;
count++;
}else{
s[num][count]='\0';
num++;
count=0;
}
}
s[num][count]='\0';//为字符串加上结尾
for(int i=0;i<=num;i++){
if(s[i][0]!='6'){//是否含6,不含则是纯单词
printf("%s",s[i]);
}else if(s[i][0]=='6'&&strlen(s[i])<=3){//含6比较6的个数
printf("%s",s[i]);
}else if(s[i][0]=='6'&&strlen(s[i])<=9){
printf("9");
}else if(s[i][0]=='6'&&strlen(s[i])>9){
printf("27");
}
if(i!=num){
printf(" ");
}
}
return 0;
}
仔细想了想不一定给出的都是单词的形式,于是我重新写了以下代码
代码实现
#include<stdio.h>
int main(){
char ch;//读入一个字符
int count=0;//从本次遇到第一个6开始6的个数
while((ch=getchar())!='\n'){//遇到回车键结束循环
if(ch!='6'&&count==0){//ch不等于6,且count为0并表示此字符原样输出
printf("%c",ch);
}else if(ch=='6'){//为6,统计个数,先不输出
count++;
}else if(ch!='6'&&count!=0){//ch不等于6,count!=0表示前面存在6,现根据6的个数决定输入,然后再打印字符ch
if(count<=3){
for(int i=0;i<count;i++){
printf("6");
}
}else if(count<=9){
printf("9");
}else{
printf("27");
}
printf("%c",ch);
count=0;//个数从新计数
}
}
if(count!=0){//遇到回车键时前面可能是一串6
if(count<=3){
for(int i=0;i<count;i++){
printf("6");
}
}else if(count<=9){
printf("9");
}else{
printf("27");
}
}
return 0;
}