我好像只能写出来这三种方法,但是总感觉能用
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地址
- 题目链接:Moving Zeros To The End
- codewars地址:codewars