Задание 6. Информатика. ЕГЭ. Шастин. 13.03.2025

Просмотры: 199
Изменено: 14 марта 2025

(Л. Шастин) Исполнитель Черепаха действует на плоскости с декартовой системой координат. В начальный момент Черепаха находится в начале координат, её голова направлена вдоль положительного направления оси ординат, хвост опущен. При опущенном хвосте Черепаха оставляет на поле след в виде линии. В каждый конкретный момент известно положение исполнителя и направление его движения. У исполнителя существует \(6\) команд: Поднять хвост, означающая переход к перемещению без рисования; Опустить хвост, означающая переход в режим рисования; Вперёд \(n\) (где \(n\) – целое число), вызывающая передвижение Черепахи на \(n\) единиц в том направлении, куда указывает её голова; Назад \(n\) (где \(n\) – целое число), вызывающая передвижение в противоположном голове направлении; Вправо \(m\) (где \(m\) – целое число), вызывающая изменение направления движения на \(m\) градусов по часовой стрелке, Влево \(m\) (где \(m\) – целое число), вызывающая изменение направления движения на \(m\) градусов против часовой стрелки. Запись

   Повтори k [Команда1 Команда2 … КомандаS]
означает, что последовательность из \(S\) команд повторится \(k\) раз.

Черепахе был дан для исполнения следующий алгоритм:

   Повтори 4 [Вперёд 36 Вправо 90 Вперёд 41 Вправо 90]
   Поднять хвост
   Вправо 90 Вперёд 20 Влево 90 Вперёд 20
   Опустить хвост
   Повтори 4 [Вперёд 25 Вправо 90]
   Поднять хвост
   Вперёд 7 Влево 90 Вперёд 7 Вправо 90
   Опустить хвост
   Повтори 7 [Вперёд 16 Вправо 90]

Определите, сколько точек с целочисленными координатами будут находиться на пересечении всех нарисованных фигур, включая точки на линиях.

Решение:

Python


from turtle import *

tracer(0)
screensize(2000, 2000)
up()
lt(90)
k = 7

for x in range(-5, 51):
    for y in range(-5, 51):
        goto(x * k, y * k)
        dot(3, 'red') if x * y % 5 == 0 else dot(2, 'green')

goto(0, 0)
down()
pensize(2)

for _ in range(4):
    fd(36 * k)
    rt(90)
    fd(41 * k)
    rt(90)
up()
rt(90)
fd(20 * k)
lt(90)
fd(20 * k)
down()
for _ in range(4):
    fd(25 * k)
    rt(90)
up()
fd(7 * k)
lt(90)
fd(7 * k)
rt(90)
down()
for _ in range(7):
    fd(16 * k)
    rt(90)
ht()
update()
done()

В результате выполнения программы получается следующий рисунок.

\(N = 10 \cdot 10 = 100.\)

Ответ: \(100\)