|
710 / 356 / 104
Регистрация: 09.02.2018
Сообщений: 805
|
||||||||||||||||
Количество пересечений отрезков17.12.2021, 21:14. Показов 5756. Ответов 19
Метки нет (Все метки)
Привет, задача такая:
На числовой прямой задано несколько отрезков координатами начальной и конечной точек. Требуется подсчитать количество пересекающихся пар отрезков. Входные данные: первая строка содержит количество отрезков N, далее N строк содержат пары чисел разделенных пробелом - координаты начальной и конечной точек отрезка. Выходные данные: одно число K - количество пересекающихся пар отрезков. Пример: input.txt
Отрезок номер 1 пересекается с отрезками 2, 3 и 5. Отрезок 2 - кроме отрезка номер 1, пересекается еще с отрезками 3, 4, 5 и 6. Отрезок 3 - пересекается еще с 4 и 5. Отрезок 4 - пересекается еще с 5. Отрезок 5 - пересекается еще с 6. Итого 3 + 4 + 2 + 1 + 1 = 11 пересечений. Мое наивное решение:
0
|
||||||||||||||||
| 17.12.2021, 21:14 | |
|
Ответы с готовыми решениями:
19
Количество пересечений прямоугольника Посчитать количество точек пересечений N отрезков плоскости Найти число пересечений отрезков |
|
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
|
|
| 17.12.2021, 21:42 | |
Сообщение было отмечено КулХацкеръ как решение
Решение
Может? :
- сортировка по первой координате, затем по второй - bisect_right второй координаты i-ого отрезка по первым координатам -> количество отрезков минус полученный индекс дает количество непересекающихся отрезков с i-м отрезком - арифметическая прогрессия от 1 до количества всех отрезков минус сумма всех значений по второму пункту
1
|
|
|
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
|
|
| 17.12.2021, 21:50 | |
|
КулХацкеръ, кури Count number of pairs of lines intersecting at a Point.
0
|
|
|
710 / 356 / 104
Регистрация: 09.02.2018
Сообщений: 805
|
||||||
| 17.12.2021, 22:22 [ТС] | ||||||
|
Gdez,
Добавлено через 32 секунды Arsegg, eaa, спасибо за подсказки, буду курить.
0
|
||||||
|
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
|
|
| 17.12.2021, 22:24 | |
|
КулХацкеръ, в 27-й минус, не плюс
1
|
|
|
710 / 356 / 104
Регистрация: 09.02.2018
Сообщений: 805
|
|
| 17.12.2021, 23:07 [ТС] | |
|
Arsegg, это не совсем то, что мне бы хотелось. Меня интересуют не прямые, а отрезки, и эти отрезки лежат на одной прямой, а не на плоскости.
Добавлено через 3 минуты Gdez, спасибо, ответ для примера из условия верный теперь! Потестирую ещё на других данных и отпишусь. Добавлено через 36 минут Все отлично, на других примерах также работает. Спасибо, очень помогли.
1
|
|
|
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
|
|||||||
| 18.12.2021, 00:30 | |||||||
0
|
|||||||
|
710 / 356 / 104
Регистрация: 09.02.2018
Сообщений: 805
|
|
| 18.12.2021, 01:24 [ТС] | |
|
idealist, спасибо, интересный вариант. Правда, по времени не проходит, но посмотрю, можно ли его доработать.
0
|
|
|
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
|
|||||||
| 18.12.2021, 04:40 | |||||||
1
|
|||||||
|
710 / 356 / 104
Регистрация: 09.02.2018
Сообщений: 805
|
|
| 18.12.2021, 15:00 [ТС] | |
|
Этот вариант лучше, но работает около 6-7 секунд. Алгоритм от Gdez работает за секунду.
Добавлено через 54 секунды Лимит времени на задачу как раз одна секунда.
0
|
|
| 18.12.2021, 15:07 | |
|
Не по теме: КулХацкеръ, попробуй на плюсы переписать.
0
|
|
|
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
|
|||||||
| 18.12.2021, 18:30 | |||||||
|
Так примерно?:
0
|
|||||||
|
710 / 356 / 104
Регистрация: 09.02.2018
Сообщений: 805
|
||||||
| 19.12.2021, 09:10 [ТС] | ||||||
|
idealist, вот что я в итоге вымучил, пытаясь улучшить твоё решение:
1
|
||||||
|
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
|
|||||||
| 19.12.2021, 10:28 | |||||||
Сообщение было отмечено КулХацкеръ как решение
Решение
1
|
|||||||
|
710 / 356 / 104
Регистрация: 09.02.2018
Сообщений: 805
|
|
| 19.12.2021, 11:21 [ТС] | |
|
Да, я написал свой код так потому, что хотел сэкономить на проверке непустоты коллекции, но твой вариант лучше читается.
0
|
|
|
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
|
||||||||
| 19.12.2021, 11:37 | ||||||||
|
Добавлено через 11 минут
1
|
||||||||
|
0 / 0 / 0
Регистрация: 21.09.2021
Сообщений: 4
|
|
| 19.12.2021, 11:44 | |
|
Интересно....
0
|
|
|
710 / 356 / 104
Регистрация: 09.02.2018
Сообщений: 805
|
|
| 19.12.2021, 18:06 [ТС] | |
|
0
|
|
| 19.12.2021, 18:06 | |
|
Помогаю со студенческими работами здесь
20
Задача на нахождение максимального кол-ва пересечений отрезков в точке (оптимизировать алгоритм) Ввести количество отрезков и их длины; найти, сколько треугольников можно составить из этих отрезков
Получить минимальное количество пересечений диапазонов из таблицы Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
|
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений.
9TO2GP2bpX4
a42b81fb172ffc12ca589c7898261ccb/
https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/
Слева синяя линия -. . .
|
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. .
Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
|
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла:
Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
|
|
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога
Финальные проекты на Си и на C++:
finish-text-sdl3-c. zip
finish-text-sdl3-cpp. zip
|
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
|
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo
Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло.
Но на выплатах по больничным это. . .
|
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2. Данные берутся из. . .
|