-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdata-test.lisp
66 lines (56 loc) · 2.08 KB
/
data-test.lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
(in-package :pc)
(defun max-2-power (num)
(labels ((%max-pow (acc)
(if (>= acc num)
acc
(%max-pow (* 2 acc)))))
(%max-pow 1)))
(defun list-to-bin-trie-inner (size lst fill)
(if (= size 1)
(if (null lst)
(cons fill lst)
lst)
(let* ((res1 (list-to-bin-trie-inner (/ size 2) lst fill))
(res2 (list-to-bin-trie-inner (/ size 2) (cdr res1) fill)))
(cons (cons (car res1)
(car res2))
(cdr res2)))))
(defun list-to-bin-trie (lst default-fill)
(let ((max-pow (max-2-power (length lst))))
(cons (car (list-to-bin-trie-inner max-pow lst default-fill))
max-pow)))
(defun bin-trie-nth-inner (trie trie-size el)
(if (atom trie)
trie
(if (= trie-size 1)
trie
(let ((half-size (/ trie-size 2)))
(if (>= el half-size)
(bin-trie-nth-inner (cdr trie) half-size (- el half-size))
(bin-trie-nth-inner (car trie) half-size el))))))
(defun bin-trie-nth (trie el)
(bin-trie-nth-inner (car trie) (cdr trie) el))
(defun bin-trie-nth-update-inner (trie trie-size el val)
(labels ((%choose-half (trie)
(let ((half-size (/ trie-size 2)))
(if (>= el half-size)
(cons (car trie) (bin-trie-nth-update-inner (cdr trie) half-size (- el half-size) val))
(cons (bin-trie-nth-update-inner (car trie) half-size el val) (cdr trie))))))
(if (= trie-size 1)
val
(if (atom trie)
(%choose-half (cons trie trie))
(%choose-half trie)))))
(defun bin-trie-nth-update (trie el val)
(cons (bin-trie-nth-update-inner (car trie) (cdr trie) el val)
(cdr trie)))
#-secd(defun bin-trie-to-list (trie)
(bin-trie-to-list-inner
(car trie)
(cdr trie)))
#-secd(defun bin-trie-to-list-inner (trie size)
(if (= size 1)
(cons trie nil)
(let ((half-size (/ size 2)))
(append (bin-trie-to-list-inner (car trie) half-size)
(bin-trie-to-list-inner (cdr trie) half-size)))))