var arr=[1,1,2,2,2,1,1,3,3,1];
分割为:var newArr=[[[1,1],[1,1],[1]],[2,2,2],[3,3]]
求一个思路,数据量很大,并且要求只能用一个for
var arr=[1,1,2,2,2,1,1,3,3,1];
分割为:var newArr=[[[1,1],[1,1],[1]],[2,2,2],[3,3]]
求一个思路,数据量很大,并且要求只能用一个for
// 抛个砖.
var arr = [1, 1, 2, 2, 2, 1, 1, 3, 3, 1];
var map = {};
var result = [];
arr.forEach((el, ind) => {
if (map[el]) {
if (ind - map[el].ind > 1) {
map[el].ind = ind;
map[el].value.push([el]);
} else {
map[el].value[map[el].value.length - 1].push(el);
map[el].ind += 1;
}
} else {
map[el] = {
value: [[el]],
ind
}
}
})
for (let k in map) {
result.push(map[k].value)
}
// result就是要的结果
arr.reduce((a,b)=>(a.arr[b] = a.arr[b] || [], a.arr[b][a.arr[b].length-(a.last === b ? 1 : 0)] = [...(a.arr[b][a.arr[b].length-(a.last === b ? 1 : 0)]||[]), b], a.last = b, a), {last: -1, arr: []}).arr.slice(1)
只遍历一次数组
如果当前数等于上一个,则结果数组的最后一个子数组更新,否则则对应数组项添加新数组。要求数字必须是大于-1的整数才行。
13 回答13.1k 阅读
7 回答2.3k 阅读
3 回答1.4k 阅读✓ 已解决
6 回答1.5k 阅读✓ 已解决
2 回答1.5k 阅读✓ 已解决
3 回答1.5k 阅读✓ 已解决
6 回答1.2k 阅读