Представьте, что у меня есть массив JS следующим образом:
var a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11];
Я хочу разбить этот массив на N меньших массивов. Например:
split_list_in_n(a, 2)
[[1, 2, 3, 4, 5, 6], [7, 8, 9, 10, 11]]
For N = 3:
[[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11]]
For N = 4:
[[1, 2, 3], [4, 5, 6], [7, 8, 9], [10, 11]]
For N = 5:
[[1, 2, 3], [4, 5], [6, 7], [8, 9], [10, 11]]
Для Python у меня есть это:
def split_list_in_n(l, cols):
""" Split up a list in n lists evenly size chuncks """
start = 0
for i in xrange(cols):
stop = start + len(l[i::cols])
yield l[start:stop]
start = stop
Для JS наилучшим правильным решением, которое я мог бы придумать, является рекурсивная функция, но мне она не нравится, потому что она сложна и уродлива. Эта внутренняя функция возвращает массив, подобный этому [1, 2, 3, null, 4, 5, 6, null, 7, 8], а затем мне нужно его снова закольтать и разбить вручную. (Моя первая попытка возвращала это: [1, 2, 3, [4, 5, 6, [7, 8, 9]]], и я решил сделать это с нулевым разделителем).
function split(array, cols) {
if (cols==1) return array;
var size = Math.ceil(array.length / cols);
return array.slice(0, size).concat([null]).concat(split(array.slice(size), cols-1));
}
Здесь jsfiddle: http://jsfiddle.net/uduhH/
Как вы это сделаете? Спасибо!