-
题目描述:
-
读入一个字符串,字符串中包含ZOJ三个字符,个数不一定相等,按ZOJ的顺序输出,当某个字符用完时,剩下的仍然按照ZOJ的顺序输出。
-
输入:
-
题目包含多组用例,每组用例占一行,包含ZOJ三个字符,当输入“E”时表示输入结束。
1<=length<=100。
-
输出:
-
对于每组输入,请输出一行,表示按照要求处理后的字符串。
具体可见样例。
-
样例输入:
-
ZZOOOJJJ ZZZZOOOOOJJJ ZOOOJJ E
-
样例输出:
-
ZOJZOJOJ ZOJZOJZOJZOO ZOJOJO
-
C++代码:
-
#include<iostream> #include<string> #include<vector> using namespace std; vector<char> Z; vector<char> O; vector<char> J; string str; int Max(int a,int b,int c){ int m=a; if(b>m) m=b; if(c>m) m=c; return m; } int main(){ while(cin>>str&&str!="E"){ for(int i=0;i<str.length();i++){ if(str.at(i)=='Z'){ Z.push_back('Z'); }else if(str.at(i)=='O'){ O.push_back('O'); }else{ J.push_back('J'); } } for(int i=0;i<Max(Z.size(),O.size(),J.size());i++){ if(i<Z.size()) cout<<'Z'; if(i<O.size()) cout<<'O'; if(i<J.size()) cout<<'J'; } cout<<endl; Z.clear(); O.clear(); J.clear(); } return 0; }