PTA L1-058 6翻了 (15 分) C++/Java

题目链接

在这里插入图片描述

“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

在这里插入图片描述

Java版-正则表达式 -最简单

import java.util.Scanner;

public class Main {
    
    
	public static void main(String[] args) {
    
    
		Scanner scanner = new Scanner(System.in);
		String str = scanner.nextLine();
		//将超过 9 个连续的 6,则将这串连续的 6 替换成 27
		str = str.replaceAll("6{10,}", "27");
		//将超过 3 个连续的 6,则将这串连续的 6 替换成 27
		str = str.replaceAll("6{4,}","9");
		//其余正常输出
		System.out.println(str);
		
	}
}

C++版 - 记录字符串各处连续出现的6的个数,根据实际输出

#include<iostream>
#include<string>
using namespace std;
int main()
{
    
    
    string str;
    getline(cin, str);
    int cnt = 0; //出现6的个数
    for (int i = 0; i <= str.length(); i++)
    {
    
    
        if (str[i]=='6')//记录连续出现的 6
        {
    
    
            cnt++;
        }
        else
        {
    
    
        	//连续出现的 6 的个数超过9 , 替换成 27 输出
            if (cnt>9)
            {
    
    
                cout << 27;
            }
            else if (cnt>3)//连续出现的 6 的个数超过3 , 替换成 9 输出
            {
    
    
                cout << 9;
            }
            else
            {
    
    
            	//其余情况 连续出现的 6 的个数小于3 有多少6照常输出
                for (int i = 0; i < cnt; i++)
                {
    
    
                    cout << 6;
                }
            }
            cnt = 0;//重新记录连续出现 6 的个数 
            cout << str[i]; //非 6 的字符不受影响 正常输出
        }
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/weixin_44695700/article/details/113666343