Практикум для студентов факультета прикладной математики и информатики в пяти частях Часть 1
Задача 3: Разрисованная плоскость
Download 1.58 Mb. Pdf ko'rish
|
book4 bib
- Bu sahifa navigatsiya:
- Задача 4: Подняться на лестницу
Задача 3: Разрисованная плоскость
Первое из решений этой задачи, которое приходит в голову, за- ключается в следующем: для каждой точки (x, y), лежащей внутри и на границе прямоугольника, вычислить значение 𝑘 = 𝑦 − 𝑥 и увеличить счётчик точек соответствующего цвета. Это решение рабо- тает только на сниженных ограничениях (так, авторское решение, осно- ванное на таком подходе, взяло 80 баллов из 100). Полное решение задачи заключается в следующем. Прежде всего, определяем, не лежит ли прямоугольник ниже линии 𝑦 = 𝑥 (в этом случае разрисованных точек внутри и на границе нет). После этого рассчитыва- ем количество цветных линий, пересекающих прямоугольник. Эта величина равна (𝑦 1 − 𝑦 2 + 1) + (𝑥 2 − 𝑥 1 ) Для каждой из таких ли- ний определяем её цвет и вари- ант пересечения с прямоуголь- ником в соответствии с рисун- ком 1, после чего рассчитываем абсциссы точек A и B. Количе- ство точек внутри и на границе прямоугольника, соответству- Рис. 1 Варианты пересечения прямой и прямоугольника A A A A B B B B 25 ющих обрабатываемой линии, равно 𝑥 𝐵 − 𝑥 𝐴 + 1. Такой алгоритм, хоть и не является оптимальным, позволяет уло- житься в заданное время для всех тестов. Авторы не захотели усложнять задачу, задавая бóльшие ограничения на размер прямоугольника. Задача 4: Подняться на лестницу Решение задачи основано на идеях динамического программирова- ния. Похожая по идее (но не по условию) задача «Экспрессные маршру- ты» была предложена на районной олимпиаде по информатике в 2007/08 учебном году. Максимальное время, за которое можно подняться по лестнице, очевидно, равно N – K и соответствует ситуации, когда Вася наступает на все ступеньки, за исключением опасных. Для расчёта минимального времени введём функцию F(i) – мини- мальное время, за которое Вася может подняться на ступеньку с номером i. Оптимальным вариантом прохода будет такой: шагнуть на ступеньку с номером i с самой дальней из неопасных ступенек, отстоящих от неё не более чем на S (или с земли). Пусть p – номер такой ступеньки. Тогда формула для расчёта F(i) примет вид 𝐹(0) = 0 𝐹(𝑖) = −1 для опасных ступенек 𝐹(𝑖) = 𝐹(𝑝) + 1 для безопасных ступенек Если каждый раз мы будем рассчитывать величину p, начиная от ступеньки i, то этот алгоритм будет иметь трудоёмкость O(N * S). Одна- ко можно заметить, что если на ступеньку i можно шагнуть со ступеньки p, то на ступеньку (i+1) можно будет ступить либо со ступеньки p либо со следующей неопасной ступеньки. Эта оптимизация позволяет реали- зовать вычисления описанного рекуррентного соотношения за линейное время. Отметим, что эти же идеи позволяют показать, что «жадный» алго- ритм, по которому мы каждый раз переходим на самую дальнюю не- опасную ступеньку, также будет давать правильный ответ. Download 1.58 Mb. Do'stlaringiz bilan baham: |
Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©fayllar.org 2024
ma'muriyatiga murojaat qiling
ma'muriyatiga murojaat qiling