0
我正在創建一個啓發式函數,它返回它應該是的,但也有堆棧溢出問題,我無法理解問題出在哪裏。下面是我創建的功能代碼:Lisp堆棧溢出遞歸函數
(defun nextPositions (position)
(let*((listaPosAdjacentes)
(positionFinal position)
(listaFinal NIL))
(setf listaPosAdjacentes (possible-actions2))
(dolist (posAdjacente listaPosAdjacentes)
(setf positionFinal position)
(setf positionFinal (list (+ (nth 0 positionFinal) (nth 0 posAdjacente))
(+ (nth 1 positionFinal) (nth 1 posAdjacente))))
(push positionFinal listaFinal))
listaFinal))
(defun push-unique (element lista)
(let ((auxlist lista))
(dolist (i lista)
(if (and (equal (nth 0 i) (nth 0 element)) (equal (nth 1 i) (nth 1 element)))
(return-from push-unique auxlist)))
(push element auxlist)
auxlist))
(defun recursive (track1 positionslist distance track)
(let ((NextValidPositions NIL))
(dolist (position positionslist)
(if (equal (track-startpos track) position)
(return-from recursive track1)
(progn (dolist (i (nextPositions position))
(if (equal (nth (nth 1 i) (nth (nth 0 i) track1)) T)
(progn
(setf NextValidPositions (push-unique i NextValidPositions))
(setf (nth (nth 1 i) (nth (nth 0 i) track1)) (+ 1 distance))))))))
(recursive track1 NextValidPositions (+ 1 distance) track)))
(defun compute-heuristic(st)
(let* ((track (state-track st))
(distance 0)
(track1Final nil)
(track1heuristica (track-env track)))
(dolist (position (track-endpositions track))
(setf (nth (nth 1 position) (nth (nth 0 position) track1heuristica)) distance))
(setf track1Final (recursive track1heuristica (track-endpositions track) distance track))
(print track1Final)
(return-from compute-heuristic track1Final)))
返回列表是什麼是應該返回,但我不明白的堆棧溢出問題。
的代碼被稱爲是這樣的:
(format t "~&Exercise 3.1 - Heuristic~&")
(with-open-file (str "out3.1.txt"
:direction :input)
(format t "~% Solution is correct? ~a~&" (equal (list (compute-heuristic (initial-state *t1*)) (compute-heuristic (make-state :pos '(1 6) :track track)) (compute-heuristic (make-state :pos '(2 8) :track track))) (read str))))
這是一個本地測試和驗證碼是由我們的教授提供測試我們的代碼,這就是爲什麼我認爲這個問題是不存在的。
任何想法可能是什麼問題? 謝謝。
在深入研究之前,您能告訴我們您是如何調用代碼的嗎?另外,一般調試提示:(跟蹤)遞歸中涉及的所有或部分功能。 –
僅供參考,有一個內置宏「PUSHNEW」,就像你的「PUSH-UNIQUE」一樣。 – Barmar
我不認爲問題出現在您發佈的代碼中。由於'(print track1Final)'正在成功執行,*之後問題就會發生*,所以它必須位於調用'compute-heuristic'的代碼中。 – Barmar