clojure 自定義排序

2021-09-27 07:12:16 字數 410 閱讀 2079

看過haskell的快速排序之後,真的是被折服了,簡潔明瞭。現在用clojure也來寫乙個快排,同樣也是相當的簡單。

(defn quick-sort [coll](if

(empty? coll)

(let [

[first & r] coll]

(concat

(quick-sort (filter #(

<

% first) r)

)[first]

(quick-sort (filter #(

>=

% first) r)))

)))演算法的定義:排過序的 list 就是令所有小於等於頭部的元素在先(它們已經排過了序), 後跟大於頭部的元素(它們同樣已經排過了序)。

DataGridView自定義排序

net自帶datagridview排序貌似最終都是用datagridview.sort 發現當是用排序後,datagridview將把排序前的行樣式等重置,仔細測試後覺得貌似是排序時datagridview重新繫結了資料來源,具體不得而知.實在沒有辦法破解,我也不想重新寫比較來排序,用了最土的辦法,...

QTableWidget 自定義排序

qtablewidget功能強大,可以在每個格仔裡新增自己的wiget部件。如果想對這些自己新增的widget進行排序有兩種方法。一種是直接設定每個格仔對應的qtablewidgetitem的值,因為qtablewidget預設是據qtablewidgetitem來排序,呼叫的比較函式是 bool ...

python list 自定義排序

看到的乙個知識點,稍加記錄 a 希望將上述的list排序,按照每條記錄中的 score 排序。如果 score 欄位的值相等,則按照 first 的值排序。如果 first 依舊相等,則按照 second 排序。如果 second 相等,則按照 third 欄位的值來排序。a.sort.doc l....