Лабораторная_работа_5. Задача 1 Штраф за левые повороты
Скачать 296.81 Kb.
|
Задача 1 «Штраф за левые повороты». В городе Х водителям запрещено выполнять левые повороты. За каждый такой поворот водитель должен уплатить штраф в размере М рублей. Для слежки за водителями в городе установлена компьютерная система, фиксирующая координаты автомобиля в начале движения, в конце движения и во время поворота. Исходные данные: N – количество зафиксированных координат автомобиля, (x i , y i ) – координаты автомобиля в процессе движения, i=1,2, …, N, где (x 1 , y 1 ) – точка начала движения, (x N , y N ) – последняя точка маршрута автомобиля. Требуется по заданной последовательности координат движения вычислить сумму штрафа водителя. Траекторию движения автомобиля можно представить в виде ломаной, состоящей из направленных отрезков из точек (x i , y i ) в точки (x i+1 , y i+1 ), i=1,2,…,N- 1.Поворот считается левым, если направление текущего отрезка пути a i+1 меняется относительно предыдущего отрезка a i в левую сторону, т.е. против часовой стрелки. Таким образом, решение задачи сводится к вычислению количества пар участков пути a i и a i+1 , для которых выполняется условие [a i × a i+1 ]>0. Координаты векторов a i и a i+1 вычисляются через координаты точек (x i , y i ): a i =(x i - x i-1 , y i - y i-1 ), a i+1 =(x i+1 - x i , y i+1 - y i ), следовательно, [a i × a i+1 ]= (x i - x i-1 ) (y i+1 - y i ) – (y i - y i-1 )(x i+1 - x i ), i=2, …, N-1. Задача 2 «Здесь будет город-сад». Жители одного дома города Х решили высадить у себя во дворе несколько деревьев. Так как жильцы не смогли договориться, как должны быть расположены посадки, то каждый посадил дерево в том месте двора, где ему захотелось. После проведения посадок полученный сад решили обнести забором. Но пока доски не привезли, деревья обвязали одной длинной веревкой. Исходная информация: N – количество деревьев в саду, (x i , y i ) – координаты деревьев, i=1,2, …, N. Так как были высажены молодые саженцы, то их толщиной можно пренебречь. Требуется определить, к каким из посаженных деревьев надо привязать веревку так, чтобы все деревья оказались внутри обнесенной зоны, а длина веревки была минимальная. Эта задача сводится к определению для заданного множества точек на плоскости выпуклой оболочки, то есть выпуклого многоугольника с вершинами в некоторых точках из заданного множества, охватывающего все его точки. Будем строить выпуклую оболочку в порядке обхода участка по часовой стрелке. Найдем самую левую точку М 0 =(x 0 , y 0 ), x 0 =min{x i }. Если таких точек несколько, то возьмем самую нижнюю из них. Эта точка наверняка принадлежит искомой выпуклой оболочке. Зададим первоначальный вектор a 0 с началом в точке (x 0 , y 0 ), параллельный оси Oy. Следующей точкой оболочки будет такая точка М 1 , чтобы вектор a 1 с началом в точке М 0 и концом в точке М 1 образовывал с первоначальным вектором a 0 минимальный угол. Если таких точек несколько, то выбирается точка, расстояние до которой максимально. (x i-1, y i-1 ) (x i, y i ) (x i+1, y i+1 ) Далее процесс продолжаем, то есть ищем точку М 2 с минимальным углом между вектором a 1 и вектором a 2 с началом в точке М 1 и концом в точке М 2 , затем точку М 3 и т.д. Процесс прекращаем, когда дойдем до первой выбранной точки или количество точек в оболочке станет равно N. Для определения угла между векторами используется скалярное произведение. Причем сам угол можно не вычислять, так как минимальному углу соответствует максимальный косинус угла. Задача 3 «Заяц». Недалеко от города Х находится зоосад. Здешний житель, заяц, хаотично прыгая, оставил след в виде замкнутой самопересекающейся ломаной, охватывающей территорию его владения. Найти площадь минимального по площади выпуклого многоугольника, описанного вокруг этой территории. В данной задаче необходимо не только найти выпуклую оболочку множества точек, но и вычислить площадь выпуклого многоугольника с заданным набором вершин. Исходные данные: N – количество вершин выпуклого многоугольника, (x i , y i ) – координаты вершин, i=1,2, …, N. Требуется определить площадь выпуклого N-угольника. Площадь N-угольника может быть вычислена как сумма площадей треугольников, из которых N-угольник составлен. Для нахождения площади треугольника используем векторное произведение. Длина векторного произведения векторов, как известно, равна удвоенной площади треугольника, построенного на этих векторах. Пусть вершины треугольника расположены в точках A=(x 1 , y 1 ), B=(x 2 , y 2 ), C=(x 3 , y 3 ). Совместим начало координат с первой точкой. Векторное произведение равно [AB × AC]= 0 0 1 3 1 3 1 2 1 2 y y x x y y x x k j i , следовательно, площадь треугольника равна S ABC =1/2 ((x 2 - x 1 ) (y 3 – y 2 ) – (y 2 - y 1 )(x 3 - x 2 )). Значение величины S ABC может быть как положительным, так и отрицательным числом, так как оно зависит от взаимной ориентации векторов AB и AC, поэтому говорят, что площадь ориентированная. Для нахождения площади N-угольника последний требуется разбить на треугольники и найти сумму ориентированных площадей этих треугольников. Разбиение N-угольника на треугольники можно провести так: зафиксировать одну из вершин N-угольника, например, первую A 1 =(x 1 , y 1 ) и рассматривать все треугольники A 1 A i A i+1 , i=2, 3,…, N-1. Заметим, что аналогичным способом можно находить площадь произвольного многоугольника. Использование свойства ориентации площади треугольника, вычисленной по А 1 А 2 А 3 А 4 А 5 векторному произведению, позволяет определить, является ли заданный многоугольник выпуклым. Для выпуклого многоугольника все треугольники, образованные тройками соседних вершин в порядке их обхода, имеют одну ориентацию. Поэтому проверка многоугольника на выпуклость может быть проведена с помощью последовательного сравнения знаков векторных произведений для всех пар соседних сторон многоугольника. Задача 4 «Тигр в загоне». Недалеко от города Х находится заповедник, в котором обитают уссурийские тигры. Работники заповедника очень переживают, когда тигр покидает охраняемую зону. Программа охраны уссурийских тигров предусматривает снабжение каждого тигра ошейником с радиомаяком. Сигнал от тигриного радиомаяка поступает в центр охраны и позволяет определить местоположения тигра. Территория заповедника представляет собой произвольный многоугольник. Исходные данные: N – количество вершин многоугольника, задающего заповедник, (x i , y i ) – координаты его вершин, i=1,2, …, N. (X, Y) – координаты точки, в которой находится тигр. Требуется определить, находится ли тигр на территории заповедника, или надо срочно снаряжать спасательную экспедицию. Очень часто при решении задач геометрического содержания требуется проверить, лежит ли заданная точка внутри или вне многоугольника. Таким способом можно решить, например, задачу о Бармаглоте, проверяя каждую точку Бармаглота относительно одеяла-многоугольника. Есть много способов проверки принадлежности точки многоугольнику, однако мы приведем здесь один из них, основанный на использовании произведения векторов. Идея метода заключается в том, чтобы определить сумму углов, под которыми стороны многоугольника видны из проверяемой точки. Если точка лежит внутри многоугольника, то суммарный угол равен 2π (точка Р на рисунке), если же точка лежит вне многоугольника, то сумма углов не равна 2π (точка Q). Таким образом, для решения надо перебрать в цикле последовательно все вершины многоугольника и найти сумму углов между векторами PA i и PA i+1 , i=1,2, …, N. Не забудьте добавить угол между векторами PA N и PA 1 . Для определения величины угла между векторами нам потребуется формула скалярного произведения. Так как стороны многоугольника должны рассматриваться последовательно, в порядке обхода вершин, то при нахождении суммарного угла следует учитывать взаимное расположение векторов. Угол, под которым сторона видна из исследуемой точки, может быть как положительным, так и отрицательным. Для определения знака угла воспользуемся векторным произведением. Знак векторного произведения и определит знак конкретного угла в общей сумме. P Q |