6.01 Определение результатов работы простейших алгоритмов управления исполнителями
Ошибка.
Попробуйте повторить позже
Исполнитель Черепаха действует на плоскости с декартовой системой координат. В начальный момент Черепаха находится в начале координат, её голова направлена вдоль положительного направления оси ординат, хвост опущен. При опущенном хвосте Черепаха оставляет на поле след в виде линии. В каждый конкретный момент известно положение исполнителя и направление его движения. У исполнителя существует две команды: Вперёд n (где n – целое число), вызывающая передвижение Черепахи на n единиц в том направлении, куда указывает её голова, Направо m (где m – целое число), вызывающая изменение направления движения на m градусов по часовой стрелке. Запись Повтори k [Команда1 Команда2 … КомандаS] означает, что последовательность из S команд повторится k раз.
Черепахе был дан для исполнения следующий алгоритм:
Повтори 4 [Вперёд 6 Направо 135 Вперёд 6]
Определите количество треугольников, которые можно увидеть в полученной фигуре.
Решение программой
Напишем программу, используя библиотеку turtle для визуализации движения Черепахи по заданному алгоритму. Основная цель — построить фигуру по алгоритму, а затем визуально или аналитически подсчитать количество треугольников, образованных линиями фигуры. Для этого сначала выполняется алгоритм Черепахи, который рисует границы фигуры. После этого можно расставить точки для наглядности и дальнейшего подсчёта треугольников. Для удобства визуализации применяется масштабирование через переменную scale, иначе фигура будет слишком маленькой. Все перемещения умножаются на scale.
from turtle import * # Модуль для работы с исполнителем Черепаха tracer(0) # Ускорение анимации движения черепахи scale = 40 # Масштаб рисунка left(90) # Поворачиваем Черепаху вверх (вдоль оси Y) # Основной алгоритм Черепахи: построение фигуры for _ in range(4): # Внешний цикл: повторяем 4 раза forward(6 * scale) # Вперёд на 6 * scale right(135) # Поворот направо на 135 градусов forward(6 * scale) # Вперёд на 6 * scale # Расставляем точки с целыми координатами для наглядности up() # Поднимаем хвост чтобы не рисовать лишние линии for x in range(-10, 10): # Перебор абсцисс точек for y in range(-10, 10): # Перебор ординат точек goto(x * scale, y * scale) # Перемещаем черепаху на точку dot(3, "blue") # Ставим точку синего цвета update() # Обновление экрана с конечным рисунком от черепахи done() # Завершение работы (окно остаётся открытым)
Осталось подсчитать количество треугольников, образованных линиями фигуры.
Решение Кумиром
Итак, после исполнения алгоритма Черепаха рисует большой треугольник, у вершины которого слева и справа находятся еще два маленьких треугольника. Поскольку при каждом повороте на 135 градусов Черепаха рисует новую линию под углом к предыдущей, формируются эти маленькие треугольники.
Специальные программы

Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное онлайн-обучение
Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.

Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!