|
0 / 0 / 0
Регистрация: 05.10.2020
Сообщений: 15
|
|
Проверить являются ли значения элементов массива суммой некоторых элементов из двух других массивов05.10.2020, 21:56. Показов 4376. Ответов 47
Метки нет (Все метки)
Задача: Заданы два массива A[1..N] и B[1..M]. Так же задана последовательность чисел C1, C2, ..., CK. Для каждого Ci выведите YES если его можно представить как сумму элемента массива A и элемента массива B, и NO в противном случае. Все элементы массивов и последовательностей во входном файле от -10^8 до 10^8.
В каждом массиве (последовательности) от 0 до 10000 элементов. ограничение времени на тест: 1 сек. ограничение памяти на тест: 65536 KB. Построение массива со всеми возможными суммами - вылет по памяти. Вывод - делать перебор, не строя новых массивов. Пробовал отсортировать сначала четные, зачем нечетные - не укладываюсь. Обычный код двумя вложенными циклами, очевидно, тоже не катит по времени. Тема задачи - сортировка. Поэтому сначала отсортировал два исходных массива, и во вложенном цикле шел, пока a[i] + b[j] <= x. Все равно долго. Подскажите алгоритм, пожалуйста.
0
|
|
| 05.10.2020, 21:56 | |
|
Ответы с готовыми решениями:
47
Создание массива с суммой элементов двух других массивов
|
|
Комп_Оратор)
|
||||||
| 06.10.2020, 17:38 | ||||||
|
driypeen, как идея (не дебажил) :
0
|
||||||
|
Комп_Оратор)
|
||
| 06.10.2020, 19:00 | ||
|
0
|
||
|
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
|
|
| 06.10.2020, 19:14 | |
|
0
|
|
|
377 / 228 / 79
Регистрация: 24.11.2009
Сообщений: 695
|
||
| 06.10.2020, 19:17 | ||
|
0
|
||
|
Комп_Оратор)
|
||
| 06.10.2020, 20:41 | ||
|
Добавлено через 29 минут н-нет... N^2*log2(N) получается. Один цикл по С[] и ещё вложенный по A[]. Тогда имеет смысл всё сортировать и нормализоать как говорит _Ivana. Если из всего вычесть самое малое значение из трёх массивов, то отрицательных значений можно избежать. Максимальное значение не превысит 2e8 что влезет в int <= 2147483647. То есть, должно получиться.
0
|
||
| 07.10.2020, 00:48 | |
|
Не по теме: Все, я сдаюсь, в секунду это не засунуть.
0
|
|
|
Комп_Оратор)
|
|||||||
| 07.10.2020, 15:48 | |||||||
std::coutЕсли не путаю то может быть:
0
|
|||||||
|
377 / 228 / 79
Регистрация: 24.11.2009
Сообщений: 695
|
||||||||||||||||
| 07.10.2020, 17:06 | ||||||||||||||||
|
IGPIGP, я не очень понимаю из каких соображений вы отсекаете часть массива.
Ну точно, TEST:
0
|
||||||||||||||||
|
Комп_Оратор)
|
|||
| 07.10.2020, 19:14 | |||
|
Если не судьба, то я начинаю двигаться по А к началу и повторяю поиск B для каждого кандидата, пока найду или не найду. Добавлено через 5 минут Кстати, для всех отрицательных C[i] можно пропускать внешний цикл совсем. Добавлено через 26 минут
0
|
|||
|
377 / 228 / 79
Регистрация: 24.11.2009
Сообщений: 695
|
|
| 07.10.2020, 19:23 | |
|
IGPIGP, подход интересный, но если я не ошибаюсь, в худшем случае будет
0
|
|
| 07.10.2020, 21:52 | |
|
0
|
|
| 07.10.2020, 21:58 | |
|
0
|
|
|
377 / 228 / 79
Регистрация: 24.11.2009
Сообщений: 695
|
||
| 07.10.2020, 22:32 | ||
|
0
|
||
|
Комп_Оратор)
|
|||
| 07.10.2020, 23:04 | |||
|
Добавлено через 13 минут
0
|
|||
| 08.10.2020, 00:56 | |
|
0
|
|
| 08.10.2020, 01:41 | |
|
0
|
|
| 08.10.2020, 02:33 | |
|
0
|
|
|
377 / 228 / 79
Регистрация: 24.11.2009
Сообщений: 695
|
|
| 18.10.2020, 02:36 | |
|
Какая-то злая задачка.
По промежуточному итогу, на белом шуме без решений (т.е. без отсечений) объемом 10к * 10к *10к, пока так: брутфорс на питоне без numpy - 9.5 часов (проверял тестовые данные) реализации на си: полный перебор = 1157 полный перебор, с в диапазоне минмакс (a + b) //1133 сек. с - а, бинарный поиск в b //69 с - а, бинарный поиск в диапазоне //38 с - а, бинарный поиск в диапазоне, 8 потоков //7 с - а, два итератора (с бинарным выбором итераторов) //4 (IGPIGP+мелкие доработки) с - а, классы вычетов над 4-х значными простыми показали от 4(?) до 11(?) секунд, но на самом деле я облажался где-то в реализации и нужно исправлять дефекты. Ну и в целом, внешний вид кода мне не нравиться, его тяжело читать. 4c8t @ 2.2GGz
0
|
|
| 18.10.2020, 02:36 | |
|
Создание массива из одинаковых элементов двух других массивов
Сформировать одномерный массив Х, значения элементов которого являются минимальные значения элементов строк массива Н(5х5) Объявить массив не более чем 15 элементов. Вывести обратные по модулю величины и проверить изменились ли адреса элементов этих двух массивов. Замените в массиве все отрицательные значения элементов суммой значений элементов первой строки массива Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Сезонность закисления почв
anaschu 04.07.2026
200 часов это все равно моловато. Есть ситуации, но нестандартные, когда смена происходит за 5 лет.
Но обычно это 50 лет и более.
Наверное, закисление почвы происходит сезонно в средней. . .
|
В чем ценность человеческого опыта в глобальном смысле?
kumehtar 03.07.2026
Возможно, ценность человека не в том, что он однажды достигает мудрости, а в том, что он становится носителем карты пути. Он знает не только истину, но и последовательность внутренних изменений,. . .
|
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS
Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
|
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи.
Через несколько переработок от PHP кода к C89 (надеюсь, 89).
Но довольно запутанно получилось. Код для Linux.
Но если убрать time и то, что с ним. . .
|
|
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки
Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
|
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы
Всем привет! Хочу поделиться свежим (и довольно. . .
|
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
|
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения:
- добавлена многоязычность
- добавлено снятие скриншотов
- добавлено поддержание бафов хождения по воде (для жреца, дк и шамана)
- и так, по. . .
|