其他分享
首页 > 其他分享> > PTA 乙级1043 输出PATest (20 分)

PTA 乙级1043 输出PATest (20 分)

作者:互联网

1043 输出PATest (20 分)

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

输入格式:

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

输出格式:

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

输入样例:

redlesPayBestPATTopTeePHPereatitAPPT
输出样例:

PATestPATestPTetPTePePee
代码思路:记录每个需要输出的字母的个数,然后依次输出,每输出一次就减掉一个,直到都为0;

#include<stdio.h>
int main()
{
	
	char a[10001];
	gets(a);
	int i,j;
	int b[6]={0};
	char c[6]={'P','A','T','e','s','t'};
	for(i=0;a[i]!='\0';i++)
	{
		if(a[i]=='P')
		{
			b[0]++;
		}
			if(a[i]=='A')
		{
			b[1]++;
		}
			if(a[i]=='T')
		{
			b[2]++;
		}
			if(a[i]=='e')
		{
			b[3]++;
		}
			if(a[i]=='s')
		{
			b[4]++;
		}
			if(a[i]=='t')
		{
			b[5]++;
		}
		
	}int count=0;
	int sum=b[0]+b[1]+b[2]+b[3]+b[4]+b[5];
	do
	{
		for(i=0;i<6;i++)
		{
			if(b[i]!=0)
			{
				printf("%c",c[i]);
				b[i]--;
				count++;
			}
		}
    }while(count<sum);

	return 0;
}

标签:1043,输出,20,字符,++,PTA,int,字符串,PATest
来源: https://blog.csdn.net/mask1010/article/details/100402412