每日一道codewars题之移动数组中所有0至数组尾部

我好像只能写出来这三种方法,但是总感觉能用sort方法搞定,如果大佬们有更好的方法,希望不吝赐教评论告诉我哈?

题目

编写一个算法,该算法采用数组并将所有零移动到最后,保留其他元素的顺序。 (Write an algorithm that takes an array and moves all of the zeros to the end, preserving the order of the other elements.)

moveZeros([false,1,0,1,2,0,1,3,"a"]) // returns[false,1,1,2,1,3,"a",0,0]
复制代码

方法一

使用reduce方法,建立一个临时数组存储0,当当前元素是0的时候就push进临时数组,不为0就return进结果数组,最后拼接两个数组

const moveZeros = arr => {
  let temp = []
  let data = arr.reduce((pre, cur) => {
    if (cur !== 0) return [...pre, cur]
    else {
      temp.push(cur)
      return [...pre]
    }
  }, [])
  return data.concat(temp)
}
复制代码

方法二

使用filter过滤出所有非0的数据,然后再使用Array.fill填充0

const moveZeros = arr => {
  let data = arr.filter(ele => ele !== 0)
  return data.concat(new Array(arr.length - data.length).fill(0))
}
复制代码

方法三

使用filter过滤出所有非0的数据,然后再filter出来等于0的 再concat

const moveZeros = arr => arr.filter(ele => ele !== 0).concat(arr.filter(ele => ele === 0))
复制代码

总结

这题好像真的很简单,哈哈毕竟只有5kyn。 最后附上题目链接和codewars地址

转载于:https://juejin.im/post/5ca09da7f265da30b773735e

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值