|
0 / 0 / 0
Регистрация: 15.01.2018
Сообщений: 5
|
|
Отрезок и точка19.05.2018, 09:28. Показов 3515. Ответов 20
Метки нет (Все метки)
Доброго времени суток)) Есть задача. Отрезок [0 1]. внутри тоже множество отрезков и точка. Найти, скольким отрезкам принадлежит точка. Перебором у меня получается, но препод сказал, что надо за O(LogN)
0
|
|
| 19.05.2018, 09:28 | |
|
Ответы с готовыми решениями:
20
Принадлежит ли отрезок фигуре Разбить отрезок на неравные части Где проведён отрезок: внутри или снаружи многоугольника |
|
677 / 479 / 216
Регистрация: 06.09.2013
Сообщений: 1,312
|
|
| 19.05.2018, 10:13 | |
Сообщение было отмечено Никита_21 как решение
Решение
Никита_21, отсортировать левые концы и правые концы отрезков, бинарным поиском искать там точку, разность между количеством элементов левее точки в первом и во втором массивах - количество отрезков, которым точка принадлежит. Вроде как-то так.
1
|
|
|
677 / 479 / 216
Регистрация: 06.09.2013
Сообщений: 1,312
|
|||||||
| 21.05.2018, 08:06 | |||||||
|
Если все отрезки заданы корректно, то можно определить бинарным поиском, сколько отрезков начинаются раньше точки - в эти отрезки точка попасть может, если они заканчиваются после нее. Далее, находим сколько отрезков заканчиваются раньше точки тоже бинарным поиском - в эти отрезки точка попасть не может. Ну собственно разность - и есть искомое количество содержащих точку отрезков. В результате сложность двух бинарных поисков - O(logN). Понятно, что затраты на сортировку концов отрезков не учитываются, O(logN) - это сложность именно "точечного" запроса. Еще один момент, в том что бинарный поиск должен быть немного разным для правых концов и для левых. В первом случае нужно количество концов не превосходящих току, а во втором - строго меньших. Вот на python, есть уже встроенные функции для этого:
0
|
|||||||
|
677 / 479 / 216
Регистрация: 06.09.2013
Сообщений: 1,312
|
|
| 21.05.2018, 12:06 | |
|
0
|
|
|
677 / 479 / 216
Регистрация: 06.09.2013
Сообщений: 1,312
|
|
| 21.05.2018, 13:15 | |
|
Ромаха, так логарифм-то лучше
128 намного больше log2(128) = 7, например
0
|
|
|
Модератор
3136 / 2283 / 469
Регистрация: 26.03.2015
Сообщений: 8,886
|
||
| 21.05.2018, 13:28 | ||
|
0
|
||
| 21.05.2018, 13:49 | |||
|
Или O(N) O(xlogx) + O(y*log(x)) Либо O(x log x) + O(x+y) Мол это ж задача на один раз. И трижды не прав тот, кто хочет ее решение за лог
0
|
|||
|
677 / 479 / 216
Регистрация: 06.09.2013
Сообщений: 1,312
|
|||
| 21.05.2018, 13:54 | |||
|
Или может концы отрезков даются уже отсортированными.
0
|
|||
|
677 / 479 / 216
Регистрация: 06.09.2013
Сообщений: 1,312
|
|
| 21.05.2018, 18:54 | |
|
Ромаха, Ну это если все точки сразу известны. А если по запросу поступают, то так не выйдет.
0
|
|
|
Модератор
3136 / 2283 / 469
Регистрация: 26.03.2015
Сообщений: 8,886
|
|
| 22.05.2018, 10:41 | |
|
0
|
|
|
Модератор
3136 / 2283 / 469
Регистрация: 26.03.2015
Сообщений: 8,886
|
|||
| 22.05.2018, 13:27 | |||
|
з.ы.
0
|
|||
| 22.05.2018, 13:49 | |||||||
0
|
|||||||
|
Модератор
3136 / 2283 / 469
Регистрация: 26.03.2015
Сообщений: 8,886
|
|
| 22.05.2018, 18:00 | |
|
0
|
|
| 22.05.2018, 18:17 | ||
|
Давайте подумаем почему. А. Понял. Потому что там не было четко сказано, что запросов много. Для большого количества точек я привел решение. O(NlogN+N)
0
|
||
| 22.05.2018, 18:17 | |
|
Помогаю со студенческими работами здесь
20
Почему в бинарном поиске сначала ищется отрезок [2**p, 2**(p+1)] ведь асимптотически сложность такая же
На отрезок [0,2] наугад бросается точка На отрезок ab длины a нанесена точка C Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога
Финальные проекты на Си и на C++:
finish-rectangles-sdl3-c. zip
finish-rectangles-sdl3-cpp. zip
|
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие.
Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
|
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ВВЕДЕНИЕ
Выполняя задание на управление насосной группой заполнения резервуара,. . .
|
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
|
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|