PTA 天梯赛习题集 L1-058 6翻了

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

字串替换的问题,找出符合条件的字串然后进行替换,详细可以参考代码
AC代码(C++)

#include <iostream>    //数据流输入/输出
#include <string>

using namespace std;

//输出有几个6,然后返回相应字符串
string is666(string str)
{
    
    
	int count = 0;
	for (string::iterator it = str.begin(); it != str.end(); it++)
		if (*it == '6')
			count++;
	if (count > 9)			//大于9个六返回27
		return "27";
	else if (count > 3)		//小于9大于3个六返回9
		return "9";
	else					//其他情况返回原本字符串
		return str;
}

int main()
{
    
    
	string str;			//读取输入的字符串
	string tmp = "";	//保存字串
	string putStr = ""; //保存输出时候的串
	getline(cin, str);	//读取一整行

	for (string::iterator it = str.begin(); it != str.end(); it++)
	{
    
    
		if (*it == '6')		//发现6把他保存进临时子串
			tmp += *it;
		else
		{
    
    
			putStr += is666(tmp);		//不是6的话检查子串情况
			putStr += *it;				//不是六的话直接接入输出串
			tmp = "";					//每次检查完字串都需要把子串清空
		}
	}
	cout << putStr + is666(tmp) << endl;		//最后检查是否有遗漏未处理的子串

	return 0;
}


猜你喜欢

转载自blog.csdn.net/m0_52072919/article/details/124569704