华为OD机考-前端-成绩排序-javaScript Node

描述

给定一些同学的信息(名字,成绩)序列,请你将他们的信息按照成绩从高到低或从低到高的排列,相同成绩

都按先录入排列在前的规则处理。

例示:
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(" "));
        });
    });
})();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值