С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 16.12.2023
Сообщений: 18

Космические лабиринты

03.12.2025, 17:35. Показов 2493. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите,пожалуйста, решить задачу. Я делаю программу, но выполняется только программа в первом окне, а их пять разных и не могу сделать так,чтобы все пять решались сразу через одну программу
Космические лабиринты
Робот-заборостроитель на пять минут остался без дела и нагородил заборов между грядками. Напишите для исполнителя Робот алгоритм движения до последней грядки. Врезаться в стены нельзя. Код должен сработать на всех пяти примерах.
Старт и финиш всегда в левом верхнем и правом нижнем углах. Между соседними грядками (столбцами клеток) всегда есть один проход.
Используйте Python и специальные функции робота.
Вид деятельности по ФРП:
создавать, выполнять вручную и на компьютере несложные алгоритмы с использованием циклов и ветвлений для управления исполнителями, такими как Робот, Черепашка, Чертёжник.
move_left()
Сделать шаг влево
move_right()
Сделать шаг вправо
move_up()
Сделать шаг вверх
move_down()
Сделать шаг вниз
wall_from_up()
Проверить, есть ли стена сверху
wall_from_down()
Проверить, есть ли стена снизу
wall_from_left()
Проверить, есть ли стена слева
wall_from_right()
Проверить, есть ли стена справа
Миниатюры
Космические лабиринты   Космические лабиринты   Космические лабиринты  

Космические лабиринты   Космические лабиринты  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.12.2025, 17:35
Ответы с готовыми решениями:

Лабиринты
Напишите программу, которая по одному лабиринту найдёт другой, подобный. Формат ввода На вход...

Космический ветер
Спутник, запущенный на околоземную орбиту, получает данные об энергии попавших в детектор...

Космический ветер
Спутник, запущенный на околоземную орбиту, получает данные об энергии попавших в детектор...

4
Вирусоборец
 Аватар для thyrex
14439 / 7481 / 1579
Регистрация: 06.09.2009
Сообщений: 27,119
03.12.2025, 18:52
С какого сайта эти задания?
1
1 / 1 / 0
Регистрация: 16.12.2023
Сообщений: 18
04.12.2025, 08:44  [ТС]
ЯндексУчебник
0
1 / 1 / 0
Регистрация: 16.12.2023
Сообщений: 18
04.12.2025, 14:47  [ТС]
Решила, если кому-нибудь нужен код, бросаю здесь
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
WIDTH = 7
HEIGHT = 7
 
# Старт: (0, 0) - верхний левый угол
# Цель:  (6, 6) - нижний правый угол
 
# Список прямых направлений и соответствующих действий робота
# dx, dy для проверки координат, функции стены и движения
DIRECTIONS = [
    ("right",  1,  0, "move_right", "wall_from_right"),
    ("down",   0,  1, "move_down",  "wall_from_down"),
    ("left",  -1,  0, "move_left",  "wall_from_left"),
    ("up",     0, -1, "move_up",    "wall_from_up"),
]
 
def solve():
    start_x, start_y = 0, 0
    goal_x, goal_y = WIDTH - 1, HEIGHT - 1
 
    visited = set()
    visited.add((start_x, start_y))
 
    # Вспомогательная функция: можно ли сделать ход в заданном направлении
    def can_move(direction, x, y):
        if direction == "right":
            if x >= WIDTH - 1:
                return False
            # Проверка стены справа от текущей клетки
            return not wall_from_right()
        elif direction == "down":
            if y >= HEIGHT - 1:
                return False
            return not wall_from_down()
        elif direction == "left":
            if x <= 0:
                return False
            return not wall_from_left()
        elif direction == "up":
            if y <= 0:
                return False
            return not wall_from_up()
        return False
 
    # Преобразование направления в новое положение
    def move_dir(direction, x, y):
        if direction == "right":
            move_right()
            return x + 1, y
        if direction == "down":
            move_down()
            return x, y + 1
        if direction == "left":
            move_left()
            return x - 1, y
        if direction == "up":
            move_up()
            return x, y - 1
        return x, y
 
    # Преобразование направления в противоположное (для возврата назад)
    def opposite(direction):
        if direction == "right":  return "left"
        if direction == "left":   return "right"
        if direction == "down":   return "up"
        if direction == "up":     return "down"
        return None
 
    # Рекурсивный DFS
    def dfs(x, y):
        # Если достигли цели
        if x == goal_x and y == goal_y:
            return True
 
        # Порядок обхода: вправо, вниз, влево, вверх (приоритет к достижению цели)
        for dir_name, dx, dy, move_fn, wall_fn in DIRECTIONS:
            if can_move(dir_name, x, y):
                nx, ny = x + dx, y + dy
                if (nx, ny) not in visited:
                    # Сделать шаг
                    if dir_name == "right":
                        move_right()
                    elif dir_name == "down":
                        move_down()
                    elif dir_name == "left":
                        move_left()
                    elif dir_name == "up":
                        move_up()
                    else:
                        # на всякий случай (не должно срабатывать)
                        continue
 
                    visited.add((nx, ny))
                    if dfs(nx, ny):
                        return True
                    # Обратный ход назад (возврат к предыдущей клетке)
                    opp = opposite(dir_name)
                    if opp == "right":
                        move_right()
                    elif opp == "down":
                        move_down()
                    elif opp == "left":
                        move_left()
                    elif opp == "up":
                        move_up()
                    # Примечание: не снимаем клетку из visited, чтобы не зацикливаться
        return False
 
    # Запуск поиска
    dfs(start_x, start_y)
 
# Вызов
solve()
1
Вирусоборец
 Аватар для thyrex
14439 / 7481 / 1579
Регистрация: 06.09.2009
Сообщений: 27,119
04.12.2025, 20:32
Цитата Сообщение от korneevany2008 Посмотреть сообщение
ЯндексУчебник
А какой класс и какой урок?

DFS для этой задачи явно не в тему. Ибо он все же для олимпиадного уровня.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.12.2025, 20:32
Помогаю со студенческими работами здесь

Космическая связь
Помогите пожалуйста, натолкните на мысль Космическая связь В этой задаче от вас потребуется...

Космическая связь
Космическая связь В этой задаче от вас потребуется написать программу для составления расписания...

Космический корабль должен доставить товар на несколько космических станций N
Космический корабль должен доставить товар на несколько космических станций N. Чтобы достигнуть...

Написать простой алгоритм Python "Посадка космического аппарата на Луну"
Никаких особых требований выдвинуто не было, задали написать обычный (не особо длинный, без...

Игра «Космическое домино»
Игра «Космическое домино». Правила. В игре участвуют только ТРЕХЗНАЧНЫЕ числа. Перед...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru