- Сортировать числовой массив (JavaScript)
- Сортировка числового массива по-возрастанию
- Сортировка числового массива по-убыванию
- Категории
- Читайте также
- Комментарии
- Вход на сайт
- Социальные сети
- Несколько полезных кейсов при работе с массивами в JavaScript
- Преобразование массиво-подобного объекта в массив
- Сумма и произведение массива
- Поиск в массиве и фильтрация массива
- Сортировка массивов
Сортировать числовой массив (JavaScript)
В ДжаваСкрипте отсортировать массив можно при помощи функции Array.sort([sortFunction]). Если не передавать функцию сортировки sortFunction , то массив будет отсортирован в порядке следования символов таблицы ASCII, проще по-алфавиту.
Чтобы отсортировать числовой массив в порядке возрастания значений, необходимо передавать функцию сортировки.
Сортировка числового массива по-возрастанию
Функция сортировки принимает два значения массива для сравнения.
Для сортировки по-возрастанию необходимо вернуть результат вычитания второго значения из первого.
// исходные данные var arr = [4, 23, 54 , 67 , 1 , 2 , 7, 90, 5, 12, 34, 21, 8, 18, 30]; arr.sort(function (a, b) < return a - b; >); console.log(arr);
В консоль отладчика будет выведен отсортированный по-возрастанию массив:
Сортировка числового массива по-убыванию
В сортировке по-убыванию все тоже самое, только нужно возвращать результат вычитания первого значения из второго.
// исходные данные var arr = [4, 23, 54 , 67 , 1 , 2 , 7, 90, 5, 12, 34, 21, 8, 18, 30]; arr.sort(function (a, b) < return b - a; >); console.log(arr);
Информация в консоли отладчика будет следующая:
Категории
Читайте также
- Массив уникальных значений (JavaScript)
- Ассоциативный массив в JavaScript
- Массив в строку (JavaScript)
- Строку в массив (JavaScript)
- Преобразовать массив в объект (PHP)
- Сортировка пузырьком (PHP)
- Заполнить массив случайными числами (JavaScript)
- Умножить массив на число (PHP)
- Случайный элемент массива (JavaScript)
- Количество элементов ассоциативного массива (JavaScript)
- Цикл в обратном порядке (PHP)
- Как удалить элемент ассоциативного массива (JavaScript)
Комментарии
Привет. Научи как получить из массива рандомное число элементов? Например, не меньше 17 и не более 26 , но всегда разное в этом диапазоне? И сохранять все в переменную. Очень поможешь !
Вход на сайт
Введите данные указанные при регистрации:
Социальные сети
Вы можете быстро войти через социальные сети:
Несколько полезных кейсов при работе с массивами в JavaScript
Очень часто на тостере вижу вопросы вида «Как отсортировать массив в JavaScript по определенному правилу?», «Как сделать с массивом в JavaScript <действие>?» и т.д.
действие>
Под катом собраны некоторые манипуляции над массивами.
Преобразование массиво-подобного объекта в массив
В es2015 была добавлена замечательная функция Array.from, которая умеет преобразовывать в массив все, что похоже на массив. Принцип ее работы следующий:
- Если в передаваемом объекте в свойстве [Symbol.iterator] есть функция, она будет использована как генератор для наполнения массива
- Если в передаваемом объекте есть свойство length, то массив будет составлен из целочисленных индексов объекта от 0 до (object.length — 1)
- В других случаях она вернет пустой массив
Из стандартных объектов массиво-подобными считаются строки (разбиваются посимвольно), генераторы, объекты класса Set, arguments и некоторые другие
Сумма и произведение массива
var arr = [1, 2, 3, 4, 5]; var sum = arr.reduce((a, b) => a + b, 0); // 15 var prod = arr.reduce((a, b) => a * b, 1); // 120
Но с суммой нужно быть аккуратнее, если в массиве встретится не числовое значение, то оно будет преобразовано в строку, и начиная с него пойдет конкатенация строк, чтобы этого избежать можно использовать более безопасный вариант:
var sum = arr.reduce((a, b) => a + (+b || 0), 0);
Поиск в массиве и фильтрация массива
Многие знают о таком замечательном методе как indexOf, который ищет в массиве переданное в первом аргументе значение по точному соответствию (value === element) и возвращает индекс первого совпадения или -1 если ничего не найдено. Так же вторым аргументом можно передать индекс, с которого нужно начать поиск.
Есть похожий на него метод lastIndexOf, работающий аналогично, только поиск производится с конца массива. Но бывают ситуации, когда поиск по точному соответствию не подходит, для этих случаев существуют методы find и findIndex работают они похожим образом, вызывая для каждого элемента функцию, переданную в первом аргументе с параметрами (element, index, array). Поиск осуществляется до тех пор, пока функция не вернет true. find возвращает сам найденный элемент или undefined если ничего не найдено, а findIndex его индекс или -1 соответственно.
Пример, найдем в массиве первый элемент, который больше 5:
var arr = [1, 4, 2, 8, 2, 9, 7]; var elem = arr.find(e => e > 5); // 8 var index = arr.findIndex(e => e > 5); // 3
Еще одна частая задача, это фильтрация массива. Для этих целей существует метод filter, который возвращает новый массив, состоящий только из тех элементов, для которых функция переданная в первом аргументе вернула true:
var arr = [1, 4, 2, 8, 2, 9, 7]; var filtredArr = arr.filter(e => e > 5); // [8, 9, 7]
Так же иногда бывает нужно просто проверить элементы массива на соответствие некоторому условию, для этого существуют методы some и every, как и предыдущие методы они работают с функцией переданной в первом аргументе:
some возвращает true, если хотя бы для одного аргумента функция вернула true, и false в противном случае
every возвращает false, если хотя бы для одного аргумента функция вернула false, и true в противном случае
Обе останавливают поиск, когда искомое значение найдено. Это можно использовать несколько нестандартно, как известно метод forEach перебирает все элементы массива, но его работу невозможно прервать, однако это становится возможным благодаря методу some:
var arr = [1, 4, 2, 8, 2, 9, 7]; arr.some(function(element, index) < console.log(index + ': ' + element); if(element === 8) < return true; //прерываем выполнение >>); /* В консоли увидим: 0: 1 1: 4 2: 2 3: 8 */
Сортировка массивов
Для сортировки массива используется метод sort. По умолчанию все элементы сортируются как строки по возрастанию кодов utf-16. Стандартное поведение можно изменить передав первым аргументом функцию-компаратор. Компаратор — это такая функция, которая получает на вход два аргумента (a, b) и должна вернуть: -1, если a идет раньше чем b; 1, если a идет позже чем b; 0, если порядок не важен, то есть аргументы равны. Метод sort довольно лоялен к компаратору и принимает на выходе любые значения меньше 0 как -1, а значения больше 0 как 1.
Важно! Метод sort, хотя и возвращает результат, все операции проводит над исходным массивом. Если необходимо оставить исходный массив без изменений, можно воспользоваться следующим приемом:
var sortedArr = arr.slice().sort();
Так как метод slice без аргументов возвращает клон массива, метод sort будет работать с этим клоном и в результате его вернет.
Простая сортировка, сравнение элементов как числа
arr.sort((a, b) => a - b); //по возрастанию arr.sort((a, b) => b - a); //по убыванию
Типобезопасная сортировка
arr.sort((a, b) => (a < b && -1) || (a >b && 1) || 0); //по возрастанию arr.sort((a, b) => (a < b && 1) || (a >b && -1) || 0); //по убыванию
Сортировка массива объектов по их свойствам
Более частая ситуация возникает, когда нужно отсортировать массив однотипных объектов по их свойству, а то и нескольким свойствам сразу, для этого удобно иметь функцию, которая создавала бы нам компаратор на любой случай жизни:
function compare(field, order) < var len = arguments.length; if(len === 0) < return (a, b) =>(a < b && -1) || (a >b && 1) || 0; > if(len === 1) < switch(typeof field) < case 'number': return field < 0 ? ((a, b) =>(a < b && 1) || (a >b && -1) || 0) : ((a, b) => (a < b && -1) || (a >b && 1) || 0); case 'string': return (a, b) => (a[field] < b[field] && -1) || (a[field] >b[field] && 1) || 0; > > if(len === 2 && typeof order === 'number') < return order < 0 ? ((a, b) =>(a[field] < b[field] && 1) || (a[field] >b[field] && -1) || 0) : ((a, b) => (a[field] < b[field] && -1) || (a[field] >b[field] && 1) || 0); > var fields, orders; if(typeof field === 'object') < fields = Object.getOwnPropertyNames(field); orders = fields.map(key =>fieldJavascript сортировка массива возрастанию); len = fields.length; > else < fields = new Array(len); orders = new Array(len); for(let i = len; i--;) < fields[i] = arguments[i]; orders[i] = 1; >> return (a, b) => < for(let i = 0; i < len; i++) < if(a[fields[i]] < b[fields[i]]) return orders[i]; if(a[fields[i]] >b[fields[i]]) return -orders[i]; > return 0; >; > //Использование arr.sort(compare()); //Обычная типобезопасная сортировка по возрастанию arr.sort(compare(-1)); //Обычная типобезопасная сортировка по убыванию arr.sort(compare('field')); //Сортировка по свойству field по возрастанию arr.sort(compare('field', -1)); //Сортировка по свойству field по убыванию /* Сортировка сначала по полю field1 при совпадении по полю field2, а если и оно совпало, то по полю field3 все по возрастанию */ arr.sort(compare('field1', 'field2', 'field3')); /* Сортировка сначала по полю field1 по возрастанию при совпадении по полю field2 по убыванию */ arr.sort(compare(< field1 : 1, field2 : -1 >));
Сортировка подсчетом
Хотя метод sort работает достаточно быстро, на очень больших массивах его скорости может оказаться недостаточно, благо есть метод сортировки который показывает большую производительность при соблюдении 2х условий, а именно — массив достаточно большой (больше 100.000 элементов) и в массиве много повторяющихся значений. Называется он сортировкой подсчетом. Я представлю пример его реализации для сортировки по возрастанию массива из числовых элементов:
function sortCounts(arr) < var counts = arr.reduce((result, value) => < if(typeof result[value] === 'undefined') < result[value] = 0; >return ++result[value], result; >, <>); var values = Object.getOwnPropertyNames(counts).sort((a, b) => a - b); var start = 0; for(let value of values) < let end = counts[value] + start; arr.fill(+value, start, end); start = end; >>