L1-058 6翻了(分数 15)

“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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值