给定一个长度不超过 104的、仅由英文字母构成的字符串。请将字符重新调整顺序,按 PATestPATest… 这样的顺序输出,并忽略其它字符。当然,六种字符的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按 PATest 的顺序打印,直到所有字符都被输出。
输入格式:
输入在一行中给出一个长度不超过 104的、仅由英文字母构成的非空字符串。
输出格式:
在一行中按题目要求输出排序后的字符串。题目保证输出非空。
输入样例:
redlesPayBestPATTopTeePHPereatitAPPT
// 结尾无空行
输出样例:
PATestPATestPTetPTePePee
// 结尾无空行
解题思路:
先获取每个PATest字符的个数,然后用 if…else if 来控制输出顺序
解题代码:
const readline = require('readline');
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout
});
let s = "";
let res = "";
let arr = new Array(6).fill(0);
rl.on('line', function(line) {
s = line;
});
rl.on('close', function() {
for(let i = 0; i < s.length; i++) {
if(s[i] == "P") {
arr[0]++;
} else if(s[i] == "A") {
arr[1]++;
} else if(s[i] == "T") {
arr[2]++;
} else if(s[i] == "e") {
arr[3]++;
} else if(s[i] == "s") {
arr[4]++;
} else if(s[i] == "t") {
arr[5]++;
}
}
for(let i = 0; i < s.length; i++) {
if(arr[0] != 0) {
res += "P";
arr[0]--;
}
if(arr[1] != 0) {
res += "A";
arr[1]--;
}
if(arr[2] != 0) {
res += "T";
arr[2]--;
}
if(arr[3] != 0) {
res += "e";
arr[3]--;
}
if(arr[4] != 0) {
res += "s";
arr[4]--;
}
if(arr[5] != 0) {
res += "t";
arr[5]--;
}
}
console.log(res)
})