|
0 / 0 / 0
Регистрация: 22.01.2017
Сообщений: 34
|
|
Функция для поиска наибольшего и второго наибольшего элемента вектора17.05.2017, 16:01. Показов 7500. Ответов 58
Метки нет (Все метки)
Есть вектор который заполняется рандомно. И нужно найти два элемента - самое большое значение и второе по величине. И главным условием сделать это с линейной сложностью.
0
|
|
| 17.05.2017, 16:01 | |
|
Ответы с готовыми решениями:
58
Функция для поиска индекса наибольшего элемента Декомпозиционный алгоритм для поиска наибольшего элемента
|
|
0 / 0 / 0
Регистрация: 22.01.2017
Сообщений: 34
|
||||||
| 17.05.2017, 20:10 [ТС] | ||||||
|
пробовал сделать так
но ошибка при поиске второго максимума. пример {16, 5,6,9,7,19,12,17,5} max=19 second_max = 16 он не ищет дальше макс. эта функция подходит для отсортированного массива, а без сортировки нельзя?
0
|
||||||
|
440 / 432 / 159
Регистрация: 21.05.2016
Сообщений: 1,338
|
|
| 18.05.2017, 00:49 | |
|
Используйте алгоритм Quickselect
Добавлено через 4 минуты Хотя, зачем..
0
|
|
|
Модератор
|
|||||||||||
| 18.05.2017, 08:15 | |||||||||||
Сообщение было отмечено S_el как решение
Решение
GraK, всё уже придумано до нас - алгоритм std::max_element. Сложность линейная.
GraK, я поторопился. Надо ещё код поправить, иногда неправильно считает. Добавлено через 3 минуты GraK, вот исправленный вариант:
GraK, всё равно иногда неправильно считает. Надо ещё подумать.
0
|
|||||||||||
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
|
| 18.05.2017, 08:28 | |
|
gru74ik, у Вас находит второй максимальный после первого максимального,
а нужно, как я понял, просто второй элемент.
0
|
|
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
|
| 18.05.2017, 08:30 | |
|
0
|
|
|
Модератор
|
||||||
| 18.05.2017, 08:43 | ||||||
|
GraK, мановар, в общем, проще отсортировать вектор и вывести два последних значения:
0
|
||||||
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
|
| 18.05.2017, 08:47 | |
|
gru74ik, сложность уже не линейная, не подходит к заданию.
Опять же Вы берете последние 2 элемента, а если у нас максимальных выпало 2 или 3. Второй по значению окажется опять максимальным.
0
|
|
|
Модератор
|
|||||||
| 18.05.2017, 09:29 | |||||||
|
мановар, а если в std::set закинуть наш вектор?
Как бы ещё узнать, за какое время это всё выполняется? Добавлено через 3 минуты
0
|
|||||||
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
||||||
| 18.05.2017, 09:54 | ||||||
Сообщение было отмечено gru74ik как решение
Решение
gru74ik, а чем max_element не подходит?
Добавлено через 2 минуты
1
|
||||||
|
Форумчанин
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
|
|
| 18.05.2017, 09:56 | |
|
0
|
|
|
Модератор
|
|
| 18.05.2017, 10:02 | |
|
мановар, как минимум тем, что алгоритм std::max_element вызывается дважды. Значит сложность будет O(2n), разве нет? Или это не так считается?
Плюс ещё цикл там у тебя. Это точно у тебя линейная сложность?
0
|
|
|
Форумчанин
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
|
|
| 18.05.2017, 10:13 | |
|
3
|
|
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
|||
| 18.05.2017, 10:14 | |||
|
0
|
|||
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
|
| 18.05.2017, 10:28 | |
|
MrGluck, да глянул и там и тут http://ru.cppreference.com/w/c... ax_element
Эти два сайта одни из основных. Такими темпами и по англикски скоро свободно переводить начну.
0
|
|
|
Модератор
|
|||||||
| 18.05.2017, 11:44 | |||||||
Предполагается, что вектор не состоит полностью из одинаковых элементов, не пуст, и не содержит только один элемент. Иначе нужно вставить соответствующие проверки.
0
|
|||||||
| 18.05.2017, 11:44 | |
|
Помогаю со студенческими работами здесь
20
Номер наибольшего элемента и наибольшего значения среди модулей Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/
O1rJuneU_ls
https:/ / vkvideo. ru/ video-115721503_456239114
|
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ВВЕДЕНИЕ
Введу сокращения:
аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
|
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi
ветка по-частям.
коммит Create переделка под биомассу. txt
вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
|
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ *
Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях.
Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её.
Последовательность действий:. . .
|
|
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
|
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение.
И на уровне агентов добавится между грибами или бактериями взаимодействий.
До того я пробовал подход через многомерные массивы,. . .
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|