Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Сложная сортировка массива с помощью метода sort() (https://javascript.ru/forum/misc/75345-slozhnaya-sortirovka-massiva-s-pomoshhyu-metoda-sort.html)

Sigizmund2012 25.09.2018 21:30

Сложная сортировка массива с помощью метода sort()
 
Здравствуйте. Есть массив:
[-2, 2, 4, 6, 8, 10, 3, 5, 7, 9, -1, -11]

Нужно преобразовать его, чтобы он удовлетворял условиям:
  1. вначале числа кратные двум, от наибольшего к наименьшему.
  2. затем оставшиеся числа от наименьшего к наибольшему.
На выходе должен получиться массив:
[ 10, 8, 6, 4, 2, -2, -11, -1, 3, 5, 7, 9 ]

Я написал адскую функцию, которая делает это, приводить её тут не вижу смысла. Можно ли за один прогон с помощью sort() отсортировать как надо?
function sortArr(array) {
            return array.sort((a, b) => {

                if (a % 2 === 0 && b % 2 === 0 && a < b) {
                    return 1;
                }

            });
        }

Эта функция реализует первую часть требований, как её переписать, чтобы удовлетворяла обоим что-то не соображу, есть идеи?

Aetae 25.09.2018 22:12

Просто берёшь и описываешь пошагово всю логику, какие проблемы:
alert(
[-2, 2, 4, 6, 8, 10, 3, 5, 7, 9, -1, -11].sort(function(a, b){
  if(a === b) return 0;

  var amod = a % 2 === 0;
  var bmod = b % 2 === 0;
  
  if(amod && bmod)
    return a > b ? -1 : 1
  if(!amod && !bmod)
    return a > b ? 1 : -1
  if(amod)
    return -1
  if(bmod)
    return 1
})
)
Потом уже можешь свернуть и сократить, но это дело десятое.


Часовой пояс GMT +3, время: 05:50.