Каковы порядки O(n) для следующих методов одновременного нахождения максимального/минимального значения массива? Что лучше? Есть ли лучшие способы?
Если бы мне пришлось заранее циклически перебирать массив по другой причине (например, умножить каждый элемент на 10), было бы лучше использовать вариант 2 и найти максимум/мин одновременно с умножением каждого элемента на один и тот же forEach?
Вариант 1:
// This is surely 2n
let a = [...Array(1000000)].map(() => Math.round(1000000 * Math.random()));
let max = Math.max(...a);
let min = Math.min(...a);
Вариант 2:
// What order is this?
let a = [...Array(1000000)].map(() => Math.round(1000000 * Math.random()));
let max = Number.MIN_SAFE_INTEGER, min = Number.MAX_SAFE_INTEGER;
a.forEach(v => {max = Math.max(max, v); min = Math.min(min, v);});
Вариант 3:
// Is this 3n/2?
let a = [...Array(1000000)].map(() => Math.round(1000000 * Math.random()));
a.sort((x,y) => x - y);
let max = a[a.length - 1];
let min = a[0];
Подробнее здесь: https://stackoverflow.com/questions/793 ... min-search
Порядок действий для одновременного поиска максимума/минимума ⇐ Javascript
Форум по Javascript
-
Anonymous
1737043758
Anonymous
Каковы порядки O(n) для следующих методов одновременного нахождения максимального/минимального значения массива? Что лучше? Есть ли лучшие способы?
Если бы мне пришлось заранее циклически перебирать массив по другой причине (например, умножить каждый элемент на 10), было бы лучше использовать вариант 2 и найти максимум/мин одновременно с умножением каждого элемента на один и тот же forEach?
Вариант 1:
// This is surely 2n
let a = [...Array(1000000)].map(() => Math.round(1000000 * Math.random()));
let max = Math.max(...a);
let min = Math.min(...a);
Вариант 2:
// What order is this?
let a = [...Array(1000000)].map(() => Math.round(1000000 * Math.random()));
let max = Number.MIN_SAFE_INTEGER, min = Number.MAX_SAFE_INTEGER;
a.forEach(v => {max = Math.max(max, v); min = Math.min(min, v);});
Вариант 3:
// Is this 3n/2?
let a = [...Array(1000000)].map(() => Math.round(1000000 * Math.random()));
a.sort((x,y) => x - y);
let max = a[a.length - 1];
let min = a[0];
Подробнее здесь: [url]https://stackoverflow.com/questions/79362270/operation-order-for-simultaneous-max-min-search[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия