|
0 / 0 / 1
Регистрация: 08.10.2015
Сообщений: 41
|
||||||
Найти минимальный по площади многоугольник25.01.2017, 11:06. Показов 2148. Ответов 2
Метки нет (Все метки)
На плоскости задано N точек своими координатами и матрица C(N*N); C(i,j)=C(j,i)=1 в случае, если вершины i и j соединены отрезком и 0 иначе. Известно, что любая вершина соединена по крайней мере с двумя другими, и что отрезки пересекаются только в концевых точках. Таким образом, вся плоскость разбивается на множество многоугольников. Задана точка Z(x,y). Найти минимальный по площади многоугольник, содержащий Z, или выдать сообщение, что такого не существует. Если Z принадлежит какому-то отрезку, то выдать его концевые точки, если Z лежит в многоугольнике, то выдать его вершины в порядке обхода по контуру.
Смог реализовать ввод точек с координатами и матрицу, с остальным запара, с геометрией, да и с математикой в общем не особо дружу, помогите дописать.
0
|
||||||
| 25.01.2017, 11:06 | |
|
Ответы с готовыми решениями:
2
Найти минимальный по площади многоугольник Найти минимальный по площади выпуклый многоугольник, что все точки лежат внутри этого многоугольника Найти контур объединения: минимальный многоугольник, охватывающий все заданные прямоугольники |
|
907 / 664 / 318
Регистрация: 23.10.2016
Сообщений: 1,543
|
||
| 25.01.2017, 20:37 | ||
|
1) Разбить граф на компоненты связности.
2) Отсортировать компоненты в порядке возрастания площадей их выпуклых оболочек. Причём точка должна входить в выпуклую оболочку, иначе компонента не даст решения. 3) Решить задачу отдельно для каждой компоненты (или пока не найдётся подходящий многоугольник). 4) Взять произвольный контур в компоненте. a) Точка находится внутри контура - Найти ребро, соединяющее две точки контура и центр которого лежит внутри контура. Таким образом контур разбивается на два, в одном из которых лежит точка Z. Продолжаем обрабатывать этот контур рекурсивно. Иначе: - Если нет точек, лежащих внутри контура, то решение найдено. Иначе: - Ищем простой путь из одной точки контура до другой, через внутреннюю точку, смежную по ребру с этим контуром. Этот путь, опять же, разобьёт контур на два, в одном из которых лежит точка Z. Продолжаем рекурсию. Иначе, если такого пути не существует: - Удалим все рёбра между контуром и его внутренними точками. Решим вне очереди задачу для подграфа, состоящего из внутренних точек контура. Если решение положительное, то решение найдено, если нет - решением является контур из предыдущего шага б) Точка находится вне контура (выполняем следующие пункты пока точка не окажется внутри контура, или контур не станет максимальным по площади (тогда, когда ни один шаг выполнить не удастся)). Если удастся найти контур в котором содержится точка Z, выполнить пункт 4a. - Найти ребро, соединяющее две точки контура и центр которого лежит вне контура. (Из двух возможных контуров, возьмём наибольший по площади). Продолжаем обрабатывать новый контур рекурсивно. Иначе: - Если нет точек, лежащих вне контура, то решения нет. Иначе: - Ищем простой путь из одной точки контура до другой, через внешнюю точку, смежную по ребру с этим контуром. При помощи этого пути увеличим наш контур. (Из двух возможных контуров, возьмём наибольший по площади). Если пути нет: - Удаляем все рёбра между контуром и внешними точками. Решением является решения для подграфа, состоящего из внешних точек. Можно забыть всё, что написано выше, перебрать все сочетания вершин, проверить каждое сочетание, образует ли оно контур, определить вхождение точки в контур, и выбрать такой контур с минимальной площадью. Добавлено через 18 минут
0
|
||
|
151 / 135 / 29
Регистрация: 02.07.2013
Сообщений: 973
|
|
| 27.01.2017, 08:31 | |
|
а многоугольники всегда будут выпуклыми?
0
|
|
| 27.01.2017, 08:31 | |
|
Помогаю со студенческими работами здесь
3
Необходимо найти минимальный по площади треугольник Найти минимальный по площади прямоугольник, покрывающий все заданные прямоугольники Егэшная задача (С4): найти отношение площади треугольника к площади трапеции. Создать базовый класс Многоугольник и наследовать от него правильный многоугольник. Ввести количество точек, получить многоугольник, закрасить многоугольник построчно. Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2.
Задача: отобразить спецтехнику, которая на данный момент находится в ремонте.
Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
|
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
|
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|