Lisp:如何从列表中包含的列表中获取元素的所有可能组合?

Lisp:如何从列表中包含的列表中获取元素的所有可能组合?,第1张

Lisp:如何从列表中包含的列表中获取元素的所有可能组合?

如果您不想使用库,可以使用以下代码执行相同的 *** 作,并可以使用任意数量的列表:

(defun combinations (&rest lists)  (if (endp lists)      (list nil)      (mapcan (lambda (inner-val)     (mapcar (lambda (outer-val)    (cons outer-val          inner-val))  (car lists)))   (apply #'combinations (cdr lists)))))[2]> (combinations '(1 2))((1) (2))[3]> (combinations '(1 2) '(3 4))((1 3) (2 3) (1 4) (2 4))[4]> (combinations '(1 2) '(3 4) '(5 6))((1 3 5) (2 3 5) (1 4 5) (2 4 5) (1 3 6) (2 3 6) (1 4 6) (2 4 6))


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5051600.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-11-15
下一篇2022-11-15

发表评论

登录后才能评论

评论列表(0条)

    保存