给定一个长度不超过 104 的、仅由英文字母构成的字符串。请将字符重新调整顺序,按 PATestPATest....
这样的顺序输出,并忽略其它字符。当然,六种字符的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按 PATest 的顺序打印,直到所有字符都被输出。
输入格式:
输入在一行中给出一个长度不超过 104 的、仅由英文字母构成的非空字符串。
输出格式:
在一行中按题目要求输出排序后的字符串。题目保证输出非空。
输入样例:
redlesPayBestPATTopTeePHPereatitAPPT
输出样例:
PATestPATestPTetPTePePee
思路:
用一个字符数组out存放'P','A','T','e','s','t',获取字符输入直到结束,每获取一个输入就和out中的字符对比,如果相同则对应的字符计数cnt[i]加1,字符总数cntall加1。
输出时,当字符总数大于0时,让 i 在0-5之间循环,如果cnt[i]>0表示相应的字符还有剩余,则输出,然后cnt[i]--,cntall--。
#include<stdio.h>
char out[6]={'P','A','T','e','s','t'};
int main(void){
char c;
int cnt[6]={0},cntall;
while(scanf("%c",&c)!=EOF){
for(int i=0;i<6;i++){
if(c==out[i]){
cnt[i]++;
cntall++;
}
}
}
for(int i=0;cntall;i=(i+1)%6){
if(cnt[i]){
printf("%c",out[i]);
cnt[i]--;
cntall--;
}
}
return 0;
}