1043 输出PATest——20分
给定一个长度不超过10000的、仅由英文字母构成的字符串。请将字符重新调整顺序,按“PATestPATest….”这样的顺序输出,并忽略其它字符。当然,六种字符的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按PATest的顺序打印,直到所有字符都被输出。
输入格式
输入在一行中给出一个长度不超过10000的、仅由英文字母构成的非空字符串。
输出格式
在一行中按题目要求输出排序后的字符串。题目保证输出非空。
输入样例
redlesPayBestPATTopTeePHPereatitAPPT
输出样例
PATestPATestPTetPTePePee
| 代码长度限制 | 时间限制 ||内存限制 |
|16 KB | 400 ms | 64 MB |
思路:
用map记录每个字母的数量,在循环中按题目要求的顺序打印就行,数量减为0自然就打不出来了
代码:
#include<bits/stdtr1c++.h>
using namespace std;
int main() {
map<char, int> mp;
string s;
getline(cin, s);
for (auto x : s) mp[x]++;
while (mp['P'] > 0 || mp['A'] > 0 || mp['T'] > 0 || mp['e'] > 0 || mp['s'] > 0 || mp['t'] > 0) {
if (mp['P']-- > 0) cout << "P";
if (mp['A']-- > 0) cout << "A";
if (mp['T']-- > 0) cout << "T";
if (mp['e']-- > 0) cout << "e";
if (mp['s']-- > 0) cout << "s";
if (mp['t']-- > 0) cout << "t";
}
return 0;
}

浙公网安备 33010602011771号