跳到主要內容

求出n取k組合的列表 Lisp版

廢話就不多說了,這次改寫Lisp版本的求組合列表,由於太久沒寫,著實吃了不少苦頭。由於Lisp版本眾,我本來想用Emacs開發,可是我把Emacs的hotkey全忘光了,只記得c-x c-e,後來就改用GNU CLispGCL),以Homebrew安裝的2.49版為主。以下是如之前效果的程式碼,看起來不太像Lisp,我寫得太不優雅了,只能盡可能寫的清楚。

(defun addlist(newList)
 (setq result (append result (list (reverse newlist))))
)

(defun calc(before all want)
 (cond 
  ((= want 0)
   (setq rest (loop for i from 1 to all append (list 0)))
   (addlist (append before rest)))
  ((= all want) 
   (setq left (- all want)) 
   (setq rest (loop for x from 1 to all append  (list 1)))
   (addlist (append before rest)))
  ((= all 1)
   (addlist (append before (list want))))
  (t 
   (calc (append before (list 0)) (- all 1) want)
   (calc (append before (list 1)) (- all 1) (- want 1)))
 )
)

(defun combinations (all want)
 (setq result (list))
 (setq lst (list) )
    (calc lst all want)
)

(combinations 3 2)
(print result)

以下是正常版組合的Lisp程式碼:
(defun addlist(newList)
 (setq result (append result (list (reverse newlist))))
)


(defun combinations (all want )
 (setq result (list))
 (setq lst (loop for x from 1 to all append  (list x))) 
    (labels ((calc (l c want)
     (when (>= (length l) want)
        (if (zerop want) (return-from calc (addlist c)))
         (calc (cdr l) c want)
         (calc (cdr l) (cons (first l) c) (1- want)))))
         (calc lst nil want))
 (setq result (reverse result))         
)

(combinations 3 2)
(print result)

留言

這個網誌中的熱門文章

Personal Bookmark

Java SE 6 + Firefox 2 UI 問題 As I do . Google拋棄了了SOAP API,浮想聯翩 https://www.gandi.net/ VS 2005 SP1中文版推出 Windows Vista中文版下載 ASP.NET 2.0網頁執行管線與快取原理 Cache 2.0快取架構與快取資料自動移除架構圖 flickr sync 分享與試用 SUN Looking Glass 3D圖形介面發布1.0 雅虎勵精圖治推動改革 Wait and see 國內某SOC疑遭駭客入侵 大砲開講 Very Important! 微軟公佈Vista安全程式介面草案 一窺Google開原碼庫房乾坤 qing is writing a dig girl net... wait and see

DBeaver 介面語言

DBeaver是我個人頗常用的一套跨平台Database管理工具,最近升級後發現Windows版本居然變成簡體中文,而且無法切換為英文。

自然人憑證讀卡機驅動程式

鳥毅用的是第一代的自然人憑證讀卡機,EZ100PU(後來有同事買EZmini可以讀SIM卡似乎更好),每年報稅時用一次。 本來只是要申請些政府業務,一時之間找不到光碟,沒想到在 驅動程式下載 居然看到Linux和Mac的驅動程式,剩下的就是政府單位的網頁和程式應該改版了吧!!!