【华为OD机试真题2023B卷 JS】整型数组按个位值排序

 

整型数组按个位值排序

时间限制:1s 空间限制:256MB 限定语言:不限

知识点:数组排序

题目描述:

给定一个非空数组(列表),其元素数据类型为整型,请按照数组元素十进制最低位从小到大进行排序,十进制最低位相同的元素,相对位置保持不变。

当数组元素为负值时,十进制最低位等同于去除符号位后对应十进制值最低位。

输入描述: 

给定一个非空数组,其元素数据类型为32位有符号整数,数组长度[1, 1000]

输出描述:

输出排序后的数组

示例1

输入:

1,2,5,-21,22,11,55,-101,42,8,7,32

输出:

1,-21,11,-101,2,22,42,32,5,55,7,8

let list = "1,2,5,-21,22,11,55,-101,42,8,7,32".split(",");
for (let i = 0; i < list.length; i++) {
    for (let j = i + 1; j < list.length; j++) {
        // 取每个数字的最低位,使用 Math.abs 去掉负号
        let lastDigitI = Math.abs(Number(list[i]) % 10);
        let lastDigitJ = Math.abs(Number(list[j]) % 10);

        // 比较最低位并交换
        if (lastDigitI > lastDigitJ) {
            [list[i], list[j]] = [list[j], list[i]];
        }
    }
}

console.log(list.join(' '));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

荔枝啵啵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值