1 / 1 / 0
Регистрация: 16.12.2023
Сообщений: 18

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

03.12.2025, 17:35. Показов 2791. Ответов 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
14450 / 7489 / 1582
Регистрация: 06.09.2009
Сообщений: 27,133
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
14450 / 7489 / 1582
Регистрация: 06.09.2009
Сообщений: 27,133
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru