Функция REVERSE в Лиспе для минимакс-альфа-бета - PullRequest
0 голосов
/ 05 ноября 2018

У меня есть функция, которую выполняет minimax-alpha-beta, дело в том, что она читает слева направо, и я хотел бы, чтобы она читала в обратном направлении, и я подумал об «обратной» функции, но не могу ее работа для меня.

Код следующий:

(defun minimax-alpha-beta (nodo alpha beta)
  (cond
    ((hoja nodo)
     (let ((val (evalua nodo)))
       (format t "~A " val)
       val))
    ((nodo-min nodo)
     (let ((beta-tmp beta))
       (do ((ch (hijos nodo) (cdr ch)))
           ((or (null ch) (<= beta-tmp alpha)) beta-tmp)
         (let ((r (minimax-alpha-beta (car ch) alpha beta-tmp)))
           (if (< r beta-tmp) (setf beta-tmp r))))))
    ((nodo-max nodo)
     (let ((alpha-tmp alpha))
       (do ((ch (hijos nodo) (cdr ch)))
           ((or (null ch) (<= beta alpha-tmp)) alpha-tmp)
         (let ((r (minimax-alpha-beta (car ch) alpha-tmp beta)))
           (if (< alpha-tmp r) (setf alpha-tmp r))))))))

И у меня есть пример дерева, реализованный так:

(defparameter *tree-001*
  '(max ((min ((max ((min (15 14))
                     (min (13 12))))
               (max ((min (11 10))
                     (min (9 8))))))
         (min ((max ((min (7 6))
                     (min (5 4))))
               (max ((min (3 2))
                     (min (1 0)))))))))

Где бы мне поставить "реверс", чтобы я делал это наоборот?

1 Ответ

0 голосов
/ 05 ноября 2018

Я предполагаю, что hijos возвращает дочерние элементы каждого узла. Это может быть то, что вы хотите повернуть вспять.

...