定义矩阵后:
(setq matriz '((1 0 0 0 0 0)
(1 1 0 0 0 0)
(0 1 1 1 0 0)
(0 0 0 1 0 0)
(0 0 0 1 1 0)
(0 0 0 0 1 1)))
我已经做了一个函数来根据位置(行和列)获取一个数字但是现在我想做一个函数来根据位置替换矩阵中的一个数字,但我在做这件事时遇到了麻烦。假设我想替换对应于 1 in (0 0 0 1 0 0) 的位置 (3 3) 我只是不知道该怎么做。只能使用递归函数,这意味着没有循环。我正在为迷宫求解器工作,感谢您的帮助:=)
:edited 部分这是我到目前为止所拥有的
(setq matriz '((1 0 0 0 0 0)(1 1 0 0 0 0)(0 1 1 1 0 0)(0 0 0 1 0 0)(0 0 0 1 1 0)(0 0 0 0 1 1)))
(defun path(i j)
(list (list (+ i 1) j)
(list (- i 1) j)
(list i (+ j 1))
(list i (- j 1))
))
(defun validsons (lf mat)
(cond
((null lf) nil)
((eq (devposmat (caar lf) (cadar lf) mat) 1) (cons (car lf) (validsons (cdr lf) mat)))
(t (validsons (cdr lf) mat))
)
)
(defun Devposicao(i lista)
(cond
((null lista) nil)
((< i 0) nil)
((= i 0) (car lista))
(t (Devposicao (- i 1) (cdr lista)))))
(defun DevPosMat(i j lista)
(Devposicao j (Devposicao i lista)))
;显示可用路径(仅 1s)
(defun rightpath(i j mat)
(validsons (path i j) mat)
)
;所以你可以正确看到矩阵而不是列表
(defun writematrix(Mat)
(cond
((null Mat) nil)
(t (progn
(print (car Mat))
(writematrix (cdr Mat))))
)
)
;这就是我试图做的替换
(defun changenumber (i j matriz)
(cond
((null matriz) nil)
((< i 0) nil)
((= i 0) (dec j (car matriz)))
(t (changenumber (- i 1) j (cdr matriz)))))
(defun dec (pos l)
(cond
((null l) nil)
((= pos 0) (cons (- (car l) 1) (cdr l)))
(t (cons (car l) (dec (- pos 1) (cdr l))))))
所以我可以使用 rightpath 向前移动并查看我有哪些可用的路径,但我只需要编辑以前的位置,所以我不会继续回到以前的位置。抱歉,如果我以错误的方式发布了一些我不习惯的内容。