PAT乙级刷题之路1043 输出PATest (20分)

1043 输出PATest (20分)

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

输入格式:
输入在一行中给出一个长度不超过 10^4的、仅由英文字母构成的非空字符串。
输出格式:
在一行中按题目要求输出排序后的字符串。题目保证输出非空。
输入样例:
redlesPayBestPATTopTeePHPereatitAPPT
输出样例:
PATestPATestPTetPTePePee

直接统计PATest的每个字符的数量在输出即可

#include <stdio.h>

int main(void)
{
	char str[10000] = {0};
	int i, num[7] = {0};
	fgets(str, 10000, stdin);
	for (i = 0; str[i] != '\0'; i++){
		if (str[i] == 'P')
			num[0]++;
		if (str[i] == 'A')
			num[1]++;
		if (str[i] == 'T')
			num[2]++;
		if (str[i] == 'e')
			num[3]++;
		if (str[i] == 's')
			num[4]++;
		if (str[i] == 't')
			num[5]++;
	}
	
	while (num[0] || num[1] || num[2] || num[3] || num[4] || num[5]){
		if (num[0] != 0)
			printf("P");
			num[0]--;	
		if (num[1] != 0)
			printf("A");
			num[1]--;
		if (num[2] != 0)
			printf("T");
			num[2]--;
		if (num[3] != 0)
			printf("e");
			num[3]--;
		if (num[4] != 0)
			printf("s");
			num[4]--;
		if(num[5] != 0)
			printf("t");
			num[5]--;
	}	
	return 0;
}

发布了73 篇原创文章 · 获赞 0 · 访问量 546

猜你喜欢

转载自blog.csdn.net/derbi123123/article/details/103780158