Помогите пожалуйста решить такую задачу:
Дано n, и координаты n вершин многоугольника (xi,yi).
Нужно найти минимальную триангуляцию этого многоугольника.
Подскажите пожалуйста какая формула при решении этой задачи динамическим программированием?
№ | Пользователь | Рейтинг |
---|---|---|
1 | tourist | 4009 |
2 | jiangly | 3823 |
3 | Benq | 3738 |
4 | Radewoosh | 3633 |
5 | jqdai0815 | 3620 |
6 | orzdevinwang | 3529 |
7 | ecnerwala | 3446 |
8 | Um_nik | 3396 |
9 | ksun48 | 3390 |
10 | gamegame | 3386 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 167 |
2 | Um_nik | 163 |
3 | maomao90 | 162 |
4 | atcoder_official | 161 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 157 |
8 | TheScrasse | 154 |
9 | Dominater069 | 153 |
9 | nor | 153 |
Помогите пожалуйста решить такую задачу:
Дано n, и координаты n вершин многоугольника (xi,yi).
Нужно найти минимальную триангуляцию этого многоугольника.
Подскажите пожалуйста какая формула при решении этой задачи динамическим программированием?
Название |
---|
Вообще в голову приходит только динамика по подмногоугольникам. Т.е. берем все возможные диагонали, дальше ответ равен сумме ответов для многоугольников, на который разбился данный, а эти многоугольники состоят из вершин исходного. На основе этой динамики можно разную статистику считать, например, минимальная триангуляция в смысле минимальной суммарной длины внутренних отрезков.UPD. На фоне этого, мой коммент можно не читать.
Пусть вершины пронумерованы от 1 до N. Пусть L[i][j] - минимальная сумма длин диагоналей по всем триангуляциям многоугольника, образованного вершинами i, i+1, ..., j. Тогда ответ на задачу это L[1][N]. Как считать L[i][j]? Рассмотрим отрезок соединяющий вершины i и j. Он должен входить в какой-то треугольник триангуляции. Переберем третью вершину k (i<k<j) этого треугольника. Для данного k понятно, что ответ равен
Итого получаем формулу
Поэтому инициализация L[i][i+2]=0 (1<=i<=N-2).
А ту формулу нужно использовать при j>i+2
Получается решение за O(N^3) с довольно маленькой константой.