0 / 0 / 0
Регистрация: 10.07.2023
Сообщений: 14
|
||||||
1 | ||||||
Что не так с кодом для задачи "Построение аквариума"? Слишком долго работает06.07.2024, 17:23. Показов 3426. Ответов 16
Решал задачу: https://codeforces.com/contest/1873/problem/E.
Подскажите, пожалуйста, что не так в моём решении, так как слишком долго оно работает для ограничений задачи. Код:
0
|
06.07.2024, 17:23 | |
Ответы с готовыми решениями:
16
Что с моим кодом не так?Он работает
Что не так с кодом? Компилируется, но не работает (связные списки) |
фрилансер
![]() 6327 / 5458 / 1108
Регистрация: 11.10.2019
Сообщений: 14,518
|
|||||||||||
06.07.2024, 17:38 | 2 | ||||||||||
Herzig00, в саму задачу я не вникал. Но если там в тестах много строк во входном файле, то получается многократное выделение памяти для вектора.
поэтому я бы вектор создал до цикла
0
|
Вездепух
![]() ![]() ![]() 12856 / 6722 / 1806
Регистрация: 18.10.2014
Сообщений: 17,020
|
|
09.07.2024, 20:19 | 3 |
К чему это здесь?
Вот это: Вы на каждой итерации цикла вычисляете количество воды тупо "по условию", то есть пробеганием по всему кораллу. Разумеется, все будет дико тормозить. И это задача не на бинарный поиск. От тут нинафиг не нужен.
1
|
![]() 596 / 379 / 184
Регистрация: 21.02.2011
Сообщений: 5,130
|
|
10.07.2024, 16:26 | 4 |
Почему? Его можно использовать для определения минимальной высоты воды, при которой количество воды будет не меньше заданного значения x, или я что-то путаю?
Вы перебираете все возможные высоты для уровня воды от минимальной до максимальной высоты с учетом среднего уровня (middleHeight), т.е. делаете лишние итерации.
0
|
Вездепух
![]() ![]() ![]() 12856 / 6722 / 1806
Регистрация: 18.10.2014
Сообщений: 17,020
|
|
10.07.2024, 16:43 | 5 |
Конечно, можно. Но бинарный поиск (по крайней мере такой, как у ТС) предполагает, что придется снова и снова вычислять объем воды для разных, никак не связанных друг с другом значений высоты. Это вычисление приходится делать в лоб, по определению, что приводит к дикой неэффективности. Если вы найдете способ "мгновенно" определять объем воды по высоте, то тогда, возможно, и такой бинарный поиск будет работать приемлемо.
Но на самом деле надо было заметить очевидное: ответ задачи не зависит от порядка кораллов в последовательности. Достаточно один раз отсортировать кораллы, и задача решится в один-единственный линейный проход по кораллам. Не понял. О каком "перебираете все возможные высоты" вы ведете речь, если у ТС в коде - бинарный поиск. Бинарный поиск не перебирает "все возможные".
1
|
![]() 596 / 379 / 184
Регистрация: 21.02.2011
Сообщений: 5,130
|
|
10.07.2024, 17:36 | 6 |
я имел в виду тоже самое, что вы и написали по поводу реализации у ТС.
0
|
![]() 3782 / 2708 / 765
Регистрация: 29.06.2020
Сообщений: 9,954
|
||||||
10.07.2024, 22:49 | 7 | |||||
На отсортированных с отловлей блох (переполнения) :
1
|
Вездепух
![]() ![]() ![]() 12856 / 6722 / 1806
Регистрация: 18.10.2014
Сообщений: 17,020
|
||||||
10.07.2024, 23:26 | 8 | |||||
1
|
случайный прохожий
![]() 3163 / 2167 / 636
Регистрация: 20.07.2013
Сообщений: 5,815
|
|
10.07.2024, 23:29 | 9 |
Можно подробности? Нужно считать суммарную высоту кораллов и исходя из этого вычислять объем воды при некоторой высоте стенок или сразу, с учетом каждого коралла, пошагово (итеративно) "уточняем" высоту стенки и получающийся объем воды?
0
|
![]() 3782 / 2708 / 765
Регистрация: 29.06.2020
Сообщений: 9,954
|
|
10.07.2024, 23:38 | 10 |
на каждом уровне пытаемся заполнить весь объем до след уровня, при этом ширина уровня повышается на уже заполненную.
на просто примере : Входные данные одного тестового примера : 9 10 1 9 2 2 9 1 3 1 3 ================= w - "ширина" пласта два числа, высота коралла и сколько их есть такой высоты, в скобках остаток воды : w = 3 1 - 3 | (7) w = 5 2 - 2 | (2) w = 7 3 - 2 | w = 9 9 - 2
1
|
![]() 3782 / 2708 / 765
Регистрация: 29.06.2020
Сообщений: 9,954
|
|
11.07.2024, 06:54 | 11 |
Неудивительно. Я тоже в него не понял. Только теперь.
Авторы из 10минутной задачи сделали цирк. Это ограничение на количество входных данных. Если бы оно было доступно описано, то и сортировка не вызывала бы никаких сомнений в её использовании. То есть, весь цирк сводится к :
0
|
случайный прохожий
![]() 3163 / 2167 / 636
Регистрация: 20.07.2013
Сообщений: 5,815
|
|
11.07.2024, 10:42 | 12 |
При этом отдельное (максимальное) значение n тоже не может превышать величины 2⋅105.
Может это какая-то попытка запутать или вовсе не стоит особо на данный момент обращать внимание. Короче, как всегда.
0
|
![]() 3782 / 2708 / 765
Регистрация: 29.06.2020
Сообщений: 9,954
|
|
11.07.2024, 14:11 | 13 |
Стоит обращать. Если не обращать, как я, то сортировка кажется слишком затратной.
Это значение n для одного теста я взял не спроста, а из того же ограничения. У нас есть t тестов (1<=t<=104). Рассмотрим случай при максимальном t и максимальном n для всех тестов. Средний случай : n / t = 105/104 = 10 То есть, 10 кораллов в каждом тесте. Теперь рассмотрим предельный случай, где в о всех тестам (кроме одного) ровно по 1 кораллу. В оставшемся получим : 105 - (104 - 1) = 90001 ~ 9*104 Можно было просто сделать задачу на тест где n <= 105 или 9*104 и не клепать ученикам мозг. Добавлено через 44 секунды Как всегда на подобных ресурсах. Мне уже стало интересно кто такую шизу им пишет, не ИИ ли ?
0
|
случайный прохожий
![]() 3163 / 2167 / 636
Регистрация: 20.07.2013
Сообщений: 5,815
|
|
11.07.2024, 17:21 | 14 |
А хз.
Ну и если тест (набор данных) один (t = 1), то nmax может быть равно тому же наиб. значению 2⋅105.
0
|
![]() 3782 / 2708 / 765
Регистрация: 29.06.2020
Сообщений: 9,954
|
|
11.07.2024, 22:05 | 15 |
0
|
14.07.2024, 06:51 | 16 |
Не по теме: Меня что-то от жары пробило на ностальгию (старею, ёшкин кот; детство-юность вспоминается, етить её мать):
0
|
0 / 0 / 0
Регистрация: 10.07.2023
Сообщений: 14
|
|
11.08.2024, 13:53 [ТС] | 17 |
Прошёл месяц, у меня к сожалению не было возможности выйти в интернет. Так вот. при ограничениях задачи бинарный поиск очень даже заходит. Оказалось, это сайт тупил, выдавал ошибку по времени, хотя ошибка была в типе данных, напихал везде ll, и зашло. Но мне интересно не это. Как бы я не пытался понять код TheCalligrapher, SmallEvil, не смог. Дело в том, что я ещё не настолько силён в плюсах, как вы, и разобрать смесь цикла через итераторы и вещей по типу assert'а не представляется возможным. Могли бы вы объяснить, пожалуйста, свой код, так как даже этот линейный проход для меня не очень понятный. Мне идея даже не совсем понятна, ну отсортировал я, а дальше что, не понятно.
0
|
11.08.2024, 13:53 | |
Помогаю со студенческими работами здесь
17
А это правда, что HDD Regenerator так долго работает на ноутбуках с жёсткими дисками Usb hdd слишком долго определяется. но работает Слишком сложно для моего неотесанного ума. Подскажите что же я делаю не так? Не могу понять что не так с кодом (сжатие кодом Хэмминга) Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
![]() |
Новые блоги и статьи
![]() |
||||
Что нового в C# 14
UnmanagedCoder 10.03.2025
Предстоящая версия C# 14 обещает принести изменения, которые сделают разработку еще более приятной и эффективной.
Что стоит отметить, так это влияние сообщества разработчиков на формирование новых. . .
|
Формулы поворота
Igor3D 10.03.2025
Добрый день
Тема
Эти формулы приводятся во множестве тьюториалов, часто под видом "матрица вращения на плоскости".
x' = x * cos(a) - y * sin(a)
y' = y * cos(a) + x * sin(a)
Как бы Вы их. . .
|
Что нового в .NET 10
UnmanagedCoder 10.03.2025
. NET 10 выходит как релиз с длительной поддержкой (LTS), включающей три года обновлений. В этом обновлении Microsoft сфокусировались на нескольких направлениях: производительность, оптимизация. . .
|
Отложенное высвобождение, RCU и Hazard Pointer в C++26
NullReferenced 09.03.2025
Многопоточное программирование стало важной частью современной разработки. Когда несколько потоков одновременно работают с общими данными, возникает целый ряд проблем, связанных с синхронизацией и. . .
|
Неблокирующийся стек на C++26
NullReferenced 09.03.2025
Традиционные способы синхронизации в многопоточном программировании — мьютексы, семафоры, условные переменные — часто превращаются в узкое место в плане производительности. При этом неблокирующиеся. . .
|
Обработка строк в C++26: Новые возможности string и string_view
NullReferenced 09.03.2025
Новый стандарт C++26 предлагает много улучшений для работы с привычными string и относительно новыми string_view.
string_view - это невладеющая ссылка на последовательность символов, появившаяся в. . .
|
Мой первый аддон для Blender 3D, с помощью нейронки (не зная даже азов пайтона, но это не значит что так и с остальным).
Hrethgir 09.03.2025
Потратил весь день. Пол-дня мне хватило, чтобы понять что с версией с 14B мне не одолеть написание функционального кода, на языке с которым я вообще никак не знаком - пайтон. Версия 22B от другого. . .
|
Einstein@Home сегодня исполняется двадцать лет!
Programma_Boinc 09.03.2025
Einstein@Home сегодня исполняется двадцать лет!
Отправлено 19 февраля 2025 года в 17:20:21 UTC
Я хочу поздравить всех наших волонтеров, разработчиков и ученых из Einstein@Home.
Мы официально. . .
|
Заполнители и расширенный набор символов в C++26
NullReferenced 09.03.2025
C++26 представляет два важных обновления: заполнители и расширенный набор символов. Заполнители (placeholders) решают давнюю проблему лаконичности кода в шаблонных выражениях и лямбда-функциях. Они. . .
|
Контракты в C++26
NullReferenced 09.03.2025
Контракты – это механизм, позволяющий указывать предусловия, постусловия и инварианты для функций в коде. Эта функциональность должна была стать частью C++20, но была исключена на встрече комитета. . .
|