|
1 / 0 / 1
Регистрация: 08.09.2018
Сообщений: 46
|
|
Как проверить вхождение элемента в массив эффективным образом?15.09.2018, 18:58. Показов 16610. Ответов 55
Метки нет (Все метки)
Встала задача:
Даны два массива, элементы которых упорядочены по возрастанию (и зачем это дали?). Найти количество уникальных элементов, то есть, которые входят в один массив, но не входят в другой. Пример a[5] = {1,2,3,4,5,6} b[6] = {3,4,5,6,7,8,9} результатом будет 5 (1,2,7,8,9) Сначала решил через множества: нашел разность a-b; b-a; затем объединил их и получил количество уникальных элементов. но вроде не пахнет эффективным решением, да и без массивов.. не думаю, что зачтут такую задачу.. Помогите с идеями, как подойти к задаче?) Спасибо всем большое.
0
|
|
| 15.09.2018, 18:58 | |
|
Ответы с готовыми решениями:
55
Вхождение одного элемента в другой массив
|
|
30 / 21 / 8
Регистрация: 23.09.2018
Сообщений: 186
|
|||||||
| 23.09.2018, 19:56 | |||||||
0
|
|||||||
|
309 / 221 / 74
Регистрация: 23.05.2011
Сообщений: 981
|
|
| 23.09.2018, 21:47 | |
|
zss, map же даёт nlogn.
n элементов массива * logn вставку. Тут уже быстрее бинарным поиском без траты лишней памяти. Вот запихнуть в unordered_map будет эффективно O(n+m) по скорости, O(min(n,m)) по памяти. Добавлено через 7 минут Croessmah, красиво. Утянул на ideone к себе.
0
|
|
|
30 / 21 / 8
Регистрация: 23.09.2018
Сообщений: 186
|
|||||||
| 23.09.2018, 22:37 | |||||||
![]()
0
|
|||||||
|
Неэпический
|
|
| 23.09.2018, 22:45 | |
|
stu4ent, она выполняет не ту работу, что требуется.
![]() Она одинаковые элементы в одном последовательности запихнет как уникальные. Кстати, этим и твой алгоритм страдает - он не выкидывает одинаковые элементы из последовательности.
1
|
|
|
30 / 21 / 8
Регистрация: 23.09.2018
Сообщений: 186
|
|
| 23.09.2018, 22:49 | |
|
По условию не сказано, что могут быть одинаковые элементы
.
0
|
|
|
Неэпический
|
||||||||
| 23.09.2018, 22:52 | ||||||||
ответ: 3 ![]() Добавлено через 2 минуты set_symmetric_difference вообще считает единички из первого массива за уникальные, хотя единичка есть во втором массиве. То есть задача не решена.
1
|
||||||||
|
Неэпический
|
||||||||
| 23.09.2018, 22:56 | ||||||||
|
Затестил алгоритмы:
0
|
||||||||
|
30 / 21 / 8
Регистрация: 23.09.2018
Сообщений: 186
|
|||||||
| 23.09.2018, 22:56 | |||||||
0
|
|||||||
|
Неэпический
|
|||||||
| 23.09.2018, 23:01 | |||||||
Только моя еще при этом в вектор вставляет. Повеселил на ночь, спасибо.
0
|
|||||||
|
30 / 21 / 8
Регистрация: 23.09.2018
Сообщений: 186
|
|||
| 23.09.2018, 23:10 | |||
![]() Добавлено через 1 минуту
0
|
|||
|
Неэпический
|
|||
| 23.09.2018, 23:16 | |||
|
Будет лучше организовать итератор, который просто посчитает, сколько раз был вставлен элемент. Но не суть, ведь это всё равно будет медленнее. ![]() set_symmetric_difference работает примерно с такой же сложностью, как и мой алгоритм, поэтому как только ты его применил, ты уже практически сравнял алгоритмы по сложности, а все остальные операции делают сложность твоего алгоритма еще больше. Применение set здесь - это вообще накладно, как по памяти, так и по времени.
0
|
|||
|
30 / 21 / 8
Регистрация: 23.09.2018
Сообщений: 186
|
|||||||
| 23.09.2018, 23:20 | |||||||
:
1) моя версия 13: мс; 2) твоя версия 10: мс.
0
|
|||||||
|
30 / 21 / 8
Регистрация: 23.09.2018
Сообщений: 186
|
|||
| 23.09.2018, 23:23 | |||
|
Добавлено через 2 минуты
0
|
|||
|
Неэпический
|
||||||||
| 23.09.2018, 23:46 | ||||||||
Сообщение было отмечено sourcerer как решение
РешениеПравда, всё равно чуть медленнее из-за unique, но эта разница уже не велика.Однако, у нас есть еще одно требование: Но это уже другая история. Теперь просто сравните производительность своего первого варианта и последнего. ))) Добавлено через 13 минут stu4ent, тут, кстати, есть еще одно НО. Если считать просто количество, то в моем алгоритме вектор и дополнительная память не нужны вообще:
1
|
||||||||
|
309 / 221 / 74
Регистрация: 23.05.2011
Сообщений: 981
|
||
| 23.09.2018, 23:48 | ||
|
0
|
||
|
30 / 21 / 8
Регистрация: 23.09.2018
Сообщений: 186
|
||
| 23.09.2018, 23:54 | ||
.
0
|
||
| 24.09.2018, 07:45 | |
|
0
|
|
| 24.09.2018, 07:45 | |
|
Как проверить условие отсутствия в строке элемента необходимого столбца( массив одномерных массивов) Как проверить вхождение значения переменной в диапазон enum? Как проверить, есть ли в ячейке вхождение одной из строк? Как проверить на однократное вхождение точки в строку, причем только в конце строки? Заполните случайным образом одномерный массив из n элементов и определите номер элемента Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу)))
Критические ошибки, мешающие компиляции и. . .
|
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата)
Этот документ предназначен для того, чтобы новый чат Claude мог продолжить
работу без необходимости заново разбираться в. . .
|
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса
Калибровка параметров симбиотической модели: технический обзор
Содержание:
Введение
Постановка проблемы
Технические аспекты реализации
Процесс внедрения изменений
|
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0»
https:/ / ibb. co/ NnkGpfMd
Представленная интегрированная схема описывает непрерывную нелинейную. . .
|
|
сукцессия 13. Питон модель трехзонного мицелия, пока что в основном арбускулярного
anaschu 28.06.2026
## Разработка агентной модели микоризной сукцессии: от выявления артефактов к созданию комплексной системы
### Аннотация
Представлено исследование по разработке агентной модели микоризной. . .
|
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики
Контекст
Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
|
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии
Введение
Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
|
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np
class PlantAgent:
def __init__(self, name, strategy, initial_biomass):
self. name = name
self. strategy = strategy # "greedy" (широколиственные) или. . .
|