-
题目描述:
-
读入一个字符串,字符串中包含ZOJ三个字符,个数不一定相等,按ZOJ的顺序输出,当某个字符用完时,剩下的仍然按照ZOJ的顺序输出。
-
输入:
-
题目包含多组用例,每组用例占一行,包含ZOJ三个字符,当输入“E”时表示输入结束。
1<=length<=100。
-
输出:
-
对于每组输入,请输出一行,表示按照要求处理后的字符串。
具体可见样例。
-
样例输入:
-
ZZOOOJJJ ZZZZOOOOOJJJ ZOOOJJ E
-
样例输出:
-
ZOJZOJOJ ZOJZOJZOJZOO ZOJOJO
AC代码:
#include<stdio.h> #include<string.h> #define N 101 int main() { //freopen("in.txt","r",stdin); char s[N]; int count[128]; //将Z,O,J的asc码作文数组下标,元素值为对应的出现次数,以空间换取时间,避免输入时的判断 while(gets(s) && strcmp(s,"E")!=0) { memset(count,0,sizeof(count)); //清零 int len = strlen(s); for(int i=0; i<len; i++) { count[s[i]]++; } while(len--) { if(count['Z'] > 0) { printf("Z"); count['Z']--; } if(count['O'] > 0) { printf("O"); count['O']--; } if(count['J'] > 0) { printf("J"); count['J']--; } } printf("\n"); } return 0; }