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

### 实现字符串中小写字母转的功能 为了实现仅转字符串中的小写字母部分,同时保持其他字符(如 `'-'`)不变,可以采用双指针法。这种方法通过两个指针分别从字符串的两端向中间移动,当两个指针都指向小写字母时,交换它们的位置;否则,跳过非字母字符。 以下是具体的实现代码和解释: ```python def reverse_only_letters(s: str) -> str: # 将字符串转换为列表以便修改 s_list = list(s) left, right = 0, len(s_list) - 1 while left < right: # 如果左指针指向的不是小写字母,则右移 if not s_list[left].isalpha(): left += 1 # 如果右指针指向的不是小写字母,则左移 elif not s_list[right].isalpha(): right -= 1 else: # 交换左右指针指向的小写字母 s_list[left], s_list[right] = s_list[right], s_list[left] left += 1 right -= 1 # 将列表转换回字符串并返回 return ''.join(s_list) ``` 上述代码中,`isalpha()` 方法用于检查字符是否为字母[^1]。如果字符是字母,则尝试进行交换;如果不是字母,则移动相应的指针跳过该字符。 #### 示例运行 以下是一个示例运行结果,展示如何处理包含小写字母和 `'-'` 的字符串: ```python input_str = "a-b-c-d" output_str = reverse_only_letters(input_str) print(output_str) # 输出:d-c-b-a ``` 在这个例子中,只有小写字母被反转,而 `'-'` 字符保持原样。 ### 注意事项 - 输入字符串可能包含多种字符,但需要确保仅对小写字母进行操作。 - 使用 `isalpha()` 方法时,会忽略所有非字母字符,因此可以安全地处理包含 `'-'` 或其他符号的字符串[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值