PAT (Basic Level) Practice (中文)1043

1043 输出PATest (20 分)

给定一个长度不超过 10​4​​ 的、仅由英文字母构成的字符串。请将字符重新调整顺序,按 PATestPATest.... 这样的顺序输出,并忽略其它字符。当然,六种字符的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按 PATest 的顺序打印,直到所有字符都被输出。

输入格式:

输入在一行中给出一个长度不超过 10​4​​ 的、仅由英文字母构成的非空字符串。

输出格式:

在一行中按题目要求输出排序后的字符串。题目保证输出非空。

输入样例:

redlesPayBestPATTopTeePHPereatitAPPT

输出样例:

PATestPATestPTetPTePePee

作者: CHEN, Yue

单位: 浙江大学

时间限制: 400 ms

内存限制: 64 MB

代码长度限制: 16 KB


#include<iostream>
#include<string>
#include<cstring>
const int N=128;
using namespace std;
int main()
{
	//这个几把题,不用map不用很麻烦,就用一个数组就完事了
	//用个数组,用个if 单分支就完事了
	/* ASCII(American Standard Code for Information Interchange,美国信息互换标准代码,ASCⅡ)是基于拉丁字母的一套电脑编码系统。它主要用于显示现代英语和其他西欧语言。它是现今最通用的单字节编码系统,并等同于国际标准ISO/IEC 646。

  ASCII第一次以规范标准的型态发表是在1967年,
	最后一次更新则是在1986年,至今为止共定义了128个字符,
	其中33个字符无法显示(这是以现今操作系统为依归,
	但在DOS模式下可显示出一些诸如笑脸、扑克牌花式等8-bit符号),
	且这33个字符多数都已是陈废的控制字符,
	控制字符的用途主要是用来操控已经处理过的文字,
	在33个字符之外的是95个可显示的字符,
	包含用键盘敲下空白键所产生的空白字符也算1个可显示字符
	(显示为空白)。*/
	int array[N]; 
	string str;
	cin>>str;
	memset(array,0,sizeof(array));
	for(int i=0;i<str.length();i++)
		array[str[i]]++;
	while(array['P']>0||array['A']>0||array['T']>0||array['e']>0||array['s']>0||array['t']>0)
	{
		if(array['P']-->0)	cout<<'P';
		if(array['A']-->0)	cout<<'A';
		if(array['T']-->0)	cout<<'T';
		if(array['e']-->0)	cout<<'e';
		if(array['s']-->0)	cout<<'s';
		if(array['t']-->0)	cout<<'t';
	}
	return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用中的说明,给定一个字符串"pat"和一个长度为104的字符串,我们需要将104个字符按照PATest的顺序重新排列,并忽略其他字符。根据引用中的代码,我们可以使用一个map来统计各个字符的出现次数。然后,我们按照PATest的顺序循环输出字符直到所有字符都被输出,每输出一个字符就将其对应的出现次数减少1。 具体步骤如下: 1. 创建一个map来统计字符出现次数。 2. 循环遍历104个字符,如果字符是"P"、"A"、"T"、"e"、"s"、"t"中的任意一个,就将其出现次数加1。 3. 创建一个字符串s1="PATest",用于按照PATest的顺序输出字符。 4. 进入一个循环,循环条件为flag等于1,表示还有字符需要输出。 5. 在循环中,遍历字符串s1,如果字符在map中的出现次数大于0,则将该字符输出,并将其出现次数减1。 6. 如果在循环中有字符被输出,则将flag设为1,表示还有字符需要输出。 7. 当循环结束后,所有字符都被输出,输出结果为PATest。 因此,根据给定的字符串"pat"和长度为104的字符串,输出应为PATest。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [PAT 1043 输出PATest](https://blog.csdn.net/qq_61117990/article/details/123307930)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [PAT 1043 输出PATest (c++)](https://blog.csdn.net/qq_42334822/article/details/122637564)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值