描述
给定一些同学的信息(名字,成绩)序列,请你将他们的信息按照成绩从高到低或从低到高的排列,相同成绩
都按先录入排列在前的规则处理。
例示:
jack 70
peter 96
Tom 70
smith 67
从高到低 成绩
peter 96
jack 70
Tom 70
smith 67
从低到高
smith 67
jack 70
Tom 70
peter 96
注:0代表从高到低,1代表从低到高
数据范围:人数:1≤n≤200 1≤n≤200
进阶:时间复杂度:O(nlogn) O(nlogn) ,空间复杂度:O(n) O(n)
输入描述:
第一行输入要排序的人的个数n,第二行输入一个整数表示排序的方式,之后n行分别输入他们的名字和成绩,以一个空格隔开
输出描述:
按照指定方式输出名字和成绩,名字和成绩之间以一个空格隔开
示例一:
输入:
3 0 fang 90 yang 50 ning 70输出:
fang 90 ning 70 yang 50
示例二:
输入:
3 1 fang 90 yang 50 ning 70输出:
yang 50 ning 70 fang 90
答案:
void (async function () {
const readline = require("readline");
const cl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let [count, sor] = [0, null];
let obj = {};
const result = [];
cl.on("line", (line) => {
if (count === 0) {
count = +line;
return;
}
if (sor === null) {
sor = +line;
return;
}
result.push(line.split(" "));
});
cl.on("close", () => {
result.sort((a, b) => (sor === 1 ? a[1] - b[1] : b[1] - a[1]));
result.map((e) => {
console.log(e.join(" "));
});
});
})();