...在js中的使用

14 篇文章 0 订阅
8 篇文章 0 订阅

看到一道算法题很简洁的解法:(用的是...这样三个点)

题目描述:给定两个排序后的数组 A 和 B,其中 A 的末端有足够的缓冲空间容纳 B。 编写一个方法,将 B 合并入 A 并排序。初始化 A 和 B 的元素数量分别为 m 和 n。

/**
 * @param {number[]} A
 * @param {number} m
 * @param {number[]} B
 * @param {number} n
 * @return {void} Do not return anything, modify A in-place instead.
 */
var merge = function(A, m, B, n) {
    A.splice(m, A.length - m, ...B.slice(0, n)); //将B插入后A的后面
    A.sort((a, b) => a - b);  //对A、B组合后的数组进行重新排序
};

这个解法真的太强了,利用...遍历B并获取到B所有的属性,然后用传递的属性覆盖现有属性,即逐个提取所有单个属性并将他们传递给新对象。

const numbers1 = [1, 2, 3, 4, 5];
const numbers2 = [ ...numbers1, 1, 2, 6,7,8]; // this will be [1, 2, 3, 4, 5, 1, 2, 6, 7, 8]

…这三个点在这个算法题里面被称为数组/对象扩展运算符,另外还有一个用处是被作为rest运算符(rest运算符接收函数接收的参数并将它们转储到以后可以使用的实数数组中)。
e.g. (rest运算符)

function sum(...numbers) {
    return numbers.reduce((accumulator, current) => {
        return accumulator += current
    });
};

sum(1,2) // 3
sum(1,2,3,4,5) // 15

参考链接:http://www.fly63.com/article/detial/1038
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值