跳到主要內容

求出n取k組合的列表 JavaScript 版,同場加映 CoffeeScript版

廢話就不說了,現在的JavaScript比起十幾年前真是好寫多了,語法這幾年來也沒有大改版,所以我這兩年花點時間學了一下現代的JavaScript語法,但程度仍然低落。

我用 node.js 直接在console執行,若沒有可以用瀏覽器的開發者工具試
addlist = function(head, tail) {
  return list.push(head + tail);
};

calc = function(before, all, want) {
  if (want === 0) {
    tail = [];
    for (i=0;i<all;i++) {
      tail += [0];
    }
    addlist(before, tail);
  } else if (all === want) {
      tail = [];
      for (i=0;i<all;i++) {
        tail += [1];
      }
      addlist(before, tail);
  } else if (all === 1) {
    addlist(before, [want]);
  } else {
    calc(before + [0], all - 1, want);
    calc(before + [1], all - 1, want - 1);
  }
};


//主程式
var all = 5;
var want = 3;
var list = [];
calc([], all, want);
console.log('共:', list.length, '個');
for (var i in list) {
  console.log(list[i]);
}

同場加映 CoffeeScript版,純粹練功一下。
addlist=(head, tail)->
   list.push head+tail
calc=(before, all, want) ->
   if want == 0
     tail=[]
     for i in [1..all]
        tail+=[0]
     addlist(before, tail)
   else if all == want
      tail = []
      for i in [1..all]
         tail +=[1]
      addlist(before, tail)
   else if all == 1
      addlist(before, [want])
   else
      calc(before+[0], all-1, want)
      calc(before+[1], all-1, want-1)
#主程式
all=5
want=3
list=[]
calc([], all, want)
console.log '共:', list.length, '個'
for a in list
   console.log a

留言

這個網誌中的熱門文章

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

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

DBeaver 介面語言

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

如何將較高版本SQL Server複製到低版本SQL Server (降級為舊版)並保留權限及資料庫圖表

一般若是要將SQL Server裡的Database轉往其他Server時,最簡單的方式就是備份(Backup)後再還原(Restore),或者是䣃離(detach)後附加(attach)。 但是很不幸地,若是由較低版本(e.g. 2008)到較高版本(e.g. 2012)要怎麼辦呢?