Разбиение массива на два массива на основе нечетного/четного положения

У меня есть массив Arr1 = [1,1,2,2,3,8,4,6].

Как я могу разбить его на два массива на основе нечетных/четных позиций элементов?

subArr1 = [1,2,3,4]
subArr2 = [1,2,8,6]

Ответ 1

Вы можете попробовать:

var Arr1 = [1,1,2,2,3,8,4,6],
    Arr2 = [],
    Arr3 = [];

for (var i=0;i<Arr1.length;i++){
    if ((i+2)%2==0) {
        Arr3.push(Arr1[i]);
    }
    else {
        Arr2.push(Arr1[i]);
    }
}

console.log(Arr2);

JS Fiddle demo.

Ответ 2

odd  = arr.filter (v) -> v % 2
even = arr.filter (v) -> !(v % 2)

Или в более идиоматическом CoffeeScript:

odd  = (v for v in arr by 2)
even = (v for v in arr[1..] by 2)

Ответ 3

Было бы проще использовать вложенные массивы:

result = [ [], [] ]

for (var i = 0; i < yourArray.length; i++)
    result[i & 1].push(yourArray[i])

Если вы ориентируетесь на современные браузеры, вы можете заменить цикл на forEach:

yourArray.forEach(function(val, i) { 
    result[i & 1].push(val)
})

Ответ 4

Функциональный подход с использованием underscore:

xs = [1, 1, 2, 2, 3, 8, 4, 6]
partition = _(xs).groupBy((x, idx) -> idx % 2 == 0)
[xs1, xs2] = [partition[true], partition[false]]

[edit] Теперь есть _. раздел:

[xs1, xs2] = _(xs).partition((x, idx) -> idx % 2 == 0)

Ответ 5

var Arr1 = [1, 1, 2, 2, 3, 8, 4, 6]
var evenArr=[]; 
var oddArr = []

var i;
for (i = 0; i <= Arr1.length; i = i + 2) {
    if (Arr1[i] !== undefined) {
        evenArr.push(Arr1[i]);
        oddArr.push(Arr1[i + 1]);
    }
}
console.log(evenArr, oddArr)

Ответ 6

Я думаю, вы можете сделать 2 для циклов, которые увеличиваются на 2 и в первом запуске цикла с 0 и во втором запуске цикла с 1

Ответ 7

Метод без модульного оператора:

var subArr1 = [];
var subArr2 = [];
var subArrayIndex = 0;
var i;
for (i = 1; i < Arr1.length; i = i+2){
    //for even index
    subArr1[subArrayIndex] = Arr1[i];
    //for odd index
    subArr2[subArrayIndex] = Arr1[i-1];
    subArrayIndex++;
}
//For the last remaining number if there was an odd length:
if((i-1) < Arr1.length){
    subArr2[subArrayIndex] = Arr1[i-1];
}

Ответ 8

Просто для удовольствия, в двух строках, учитывая, что он был отмечен coffeescript:

Arr1 = [1,1,2,2,3,8,4,6]

[even, odd] = [a, b] = [[], []]
([b,a]=[a,b])[0].push v for v in Arr1

console.log even, odd
# [ 1, 2, 3, 4 ] [ 1, 2, 8, 6 ]

Ответ 9

В качестве улучшения однострочной линии для решения tokland с использованием функции цепной связи подчеркивания:

xs = [1, 1, 2, 2, 3, 8, 4, 6]
_(xs).chain().groupBy((x, i) -> i % 2 == 0).values().value()

Ответ 10

filters - это нестатический и не встроенный метод Array, который принимает literal object функций фильтров и возвращает literal object массивов, где ввод и вывод сопоставляются объектными ключами.

    Array.prototype.filters = function (filters) {
      let results = {};
      Object.keys(filters).forEach((key)=>{
         results[key] = this.filter(filters[key])   
      }); 
      return results;
    }
    //---- then : 
    
    console.log(
      [12,2,11,7,92,14,5,5,3,0].filters({
        odd:  (e) => (e%2),
        even: (e) => !(e%2)
      })
    )