リーフノードを作成するmake-leaf-setというプロシージャと、最も低いものから高いものへと並べ替える別のプロシージャがあります。
(define (make-leaf-set pairs)
(if (null? pairs)
'()
(let ((pair (car pairs)))
(adjoin-set (make-leaf (car pair)
(cdr pair))
(make-leaf-set (cdr pairs))))))
(define (adjoin-set x set)
(cond ((null? set) (list x))
((< (weight x) (weight (car set))) (cons x set))
(else (cons (car set)
(adjoin-set x (cdr set))))))
"Predefined dotted paires"
(define pairs '((a . 2) (b . 5) (c . 1) (d . 3) (e . 1) (f . 3)))
=> ((leaf e 1) (leaf c 1) (leaf a 2) (leaf f 3) (leaf d 3) (leaf b 5))
ペアは使用すると完全に機能します(make-leaf-setペア)。すべてが並べ替えられます。また、make-code-treeと呼ばれる別の手順を使用します
(define (make-code-tree left right)
(list left
right
(append (symbols left) (symbols right))
(+ (weight left) (weight right))))
(define (symbols tree)
(if (leaf? tree)
(list (symbol-leaf tree))
(caddr tree)))
(define (weight tree)
(if (leaf? tree)
(weight-leaf tree)
(cadddr tree)))
- 目標は、ペアのリストを取得してからハフマンツリーを作成するプロシージャを作成することです。
始めに私はこれを思いついた
(define (grow-huffman-tree list)
(successive-merge (make-leaf-set list) '()))
(define (successive-merge par tree)
(if (null? par)
tree
(append (make-code-tree (car par) (cadr par)) tree)))
座っていると、最初の2つの要素がマージされ、が与えられ((leaf e 1) (leaf c 1) (e c) 2)
ます。しかし、私はそれがすべての葉をマージしてハフマンツリーのように構築されるようにしたいので、他の葉をこのツリーにマージすることはできません。呼び出そうとすると(successive-merge (cdr par) tree)
、要素d3でエラーが発生します...