PTA L1-058 6翻了

题目重现:

“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

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

实现思路:

  1. 遍历字符串

    • 遍历字符串 a 的每一个字符 a[i]
    • 如果当前字符是 '6',则 n 自增1。
    • 如果当前字符不是 '6',则根据 n 的值进行相应的替换操作,并输出当前字符 a[i],然后重置 n 为0。
  2. 替换操作

    • 如果 n 小于等于3,原样输出所有连续的 '6'。
    • 如果 n 大于3且小于等于9,输出一个 '9'。
    • 如果 n 大于9,输出 '27'。
  3. 处理字符串末尾

    • 在遍历结束后,检查 n 的值,因为最后一个字符可能是 '6',需要单独处理字符串末尾的连续 '6'。
    • 根据 n 的值,执行相应的替换操作

关键代码:

if(k>0)
    {
            if(n<=3){
                for(int j=0;j<n;j++)
                    cout<<"6";
            }
            else if(n>3&&n<=9)
                cout<<"9";
            else cout<<"27";
    }

通过截图:

完整代码:

#include <iostream>
#include<bits/stdc++.h>
using namespace std;

int main()
{
    string a;
    int n=0;
    getline(cin,a);
    size_t k=a.size();
    for(int i=0;i<k;i++)
    {
        if(a[i]=='6')n++;
        else{
            if(n<=3){
                for(int j=0;j<n;j++)
                    cout<<"6";
            }
            else if(n>3&&n<=9)
                cout<<"9";
            else cout<<"27";
            cout<<a[i];
            n=0;
        }
    }
    if(k>0)
    {
            if(n<=3){
                for(int j=0;j<n;j++)
                    cout<<"6";
            }
            else if(n>3&&n<=9)
                cout<<"9";
            else cout<<"27";
    }
    return 0;
}

 

  • 18
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值