С Новым годом! Форум программистов, компьютерный форум, киберфорум
Lisp
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
Marinka
1

Разработать программу для поиска пути в лабиринте

01.10.2014, 00:19. Показов 1985. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте! Помогите, пожалуйста​, разработать программу для поиска пути в лабиринте на лиспе. Предусмотреть возможность задания входа и выхода, наглядное представление найденных решений. Нашла такую программу, но на Home Lisp она не работает. Подскажите, пожалуйста, почему. Спасибо!
Lisp
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
(defun find_room (point labirint) 
 
(cond ((null labirint) nil) 
 
((eql (caar labirint) point) (second (car labirint))) 
 
(t (find_room point (cdr labirint)))))
 
 
 
(defun find_path_r (labyrinth path) 
 
(let ((room (find_room (car path) labyrinth))) 
 
(case room 
 
((nil) nil) 
 
((out) (nreverse (cons 'out path))) 
 
(t (find_path_r labyrinth (cons room path)))))) 
 
 
 
(defun find_path (labyrinth) 
 
(find_path_r labyrinth (cons 'in nil)))
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.10.2014, 00:19
Ответы с готовыми решениями:

Программа поиска пути в лабиринте
Здравствуйте! Задали в универе написать программу на Билдере, которая бы искала путь в лабиринте....

Алгоритм поиска пути в лабиринте
159 ошибок помогите разобраться #include "conio.h" // Для функции getch() #include <string.h>...

алгоритм поиска кротчайшего пути в лабиринте
суть в том, чтобы найти кротчайший путь в лабиринте, организованном в StringGrind случайным образом...

Реализация волнового алгоритма поиска пути в лабиринте
Люди прошу помощи бьюсь над этой фигнёй уже 3 недели. На форуме впервые прошу не ругать за...

3
Модератор
Эксперт функциональных языков программированияЭксперт Python
37431 / 20803 / 4280
Регистрация: 12.02.2012
Сообщений: 34,217
Записей в блоге: 14
01.10.2014, 10:16 2
Дорогая Marinka, знаешь, чем отличается вдумчивый студент от... не очень? Вдумчивый никогда не скажет просто "не работает". Это слова не программиста, а юзера. Какую ошибку выдает программа в HomeLisp?

Добавлено через 1 час 40 минут
Вот работающий код поиска пути, основанный на обходе в глубину. Путь, конечно, получается далеко не всегда кратчайший. Графы задаются списками ребер.

Lisp
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
(defun search (v graph chk)  ;; найти первую вершину, связанную с v и непосещенную
  (dolist (i graph nil)
    (when (and (eq v (car i)) (not (member (cadr i) chk))) (return (cadr i)))
    (when (and (eq v (cadr i)) (not (member (car i) chk))) (return (car i)))))
 
(defun dfs! (graph &optional (chk '(1)) (stack '(1))) ;; обход в глубину
  (let ((w (if (null stack) nil (search (car stack) graph chk))))
       (cond ((and (null w) (null stack)) nil)
             ((null w) (dfs! graph chk (cdr stack)))
             (t (cons (list (car stack) w) (dfs! graph (cons w chk) (cons w stack)))))))
 
(defun dfs (graph v)  ;; более удобный интерфейс обхода в глубину
  (dfs! graph (list v) (list v)))
 
(defun search-path (lst e) ;; поиск пути
  (cond ((null lst) nil)
        ((eq (cadar lst) e) (list (car lst)))
        (t (cons (car lst) (search-path (cdr lst) e)))))
 
(defun task (graph b e) ;; собственно решение
  (search-path (dfs graph b) e))
 
;; пробуем:
 
(task '((1 2) (1 3) (2 4) (2 5) (3 5) (3 6) (4 5) (5 6)) 1 5)
 
==> ((1 2) (2 4) (4 5))
4
0 / 0 / 0
Регистрация: 20.09.2014
Сообщений: 9
01.10.2014, 22:56 3
Подскажите, почему не выдает результат
Миниатюры
Разработать программу для поиска пути в лабиринте  
0
Модератор
Эксперт функциональных языков программированияЭксперт Python
37431 / 20803 / 4280
Регистрация: 12.02.2012
Сообщений: 34,217
Записей в блоге: 14
02.10.2014, 11:37 4
Цитата Сообщение от Anko Посмотреть сообщение
Подскажите, почему не выдает результат
- старое ядро HomeLisp. В Этой нити лежит более свежее ядро. Скачайте, распакуйте и замените файлы на новые.
1
02.10.2014, 11:37
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.10.2014, 11:37
Помогаю со студенческими работами здесь

Алгоритм поиска пути в лабиринте, заданном связным графом
использовать алгоритм поиска пути в лабиринте, заданном связным графом. граф уже задан в самой...

Рекурсия (не могу из нее выйти) поиска пути в лабиринте
Добрый день, друзья! Пытаюсь реализовать программу, которая бы находила путь в лабиринте(интовый...

Исправить программу нахождения пути в лабиринте
Не могу доделать Лабиринт Вот код программы Program meh; uses crt; var mass:array of...

Нужен алгоритм поиска пути в этом лабиринте (будь то волновой алгоритм или алгоритм правой/левой руки )
#include "stdafx.h" #include <iostream> #include <conio.h> using namespace std; void lab...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на Go/Golang
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C#
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
Это работает. Скорость асинхронной логики велика. Вопрос видимо останется в стабильности. Плата - огонь!
Hrethgir 13.01.2025
По прошлому проекту в Logisim Evolution https:/ / www. cyberforum. ru/ blogs/ 223907/ blog8781. html прилагаю файл архива проекта в Gowin Eda. Восьмибитный счётчик из сумматора+ генератор сигнала. . .
UserScript для подсветки кнопок языков программировани­­­­я в зависимости от текущего раздела
volvo 13.01.2025
В результате работы этого скрипта подсвечиваются нужные кнопки не только в форме быстрого ответа, но и при редактировании сообщения: / / ==UserScript== / / @name CF_DefaultLangSelect / / . . .
Введение в модели и алгоритмы машинного обучения
InfoMaster 12.01.2025
Машинное обучение представляет собой одну из наиболее динамично развивающихся областей искусственного интеллекта, которая фокусируется на разработке алгоритмов и методов, позволяющих компьютерам. . .
Как на Python создать нейросеть для решения задач
InfoMaster 12.01.2025
В контексте стремительного развития современных технологий особое внимание уделяется таким инструментам, как нейросети. Эти структуры, вдохновленные биологическими нейронными сетями, используются для. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru