diff options
author | Masaya Tojo <masaya@tojo.tokyo> | 2021-07-25 10:44:16 +0900 |
---|---|---|
committer | Masaya Tojo <masaya@tojo.tokyo> | 2021-07-25 10:45:01 +0900 |
commit | 705f1d5c6d5ee8d1f3f84dfc9079801bec49b2b6 (patch) | |
tree | a5b83557e16f5b70b8bc39b462c066911696afa6 /L-99.lisp | |
parent | b729e723d88a3f07320f6c5a6527747f8f668870 (diff) |
L-99: Solve P13 problem.
Diffstat (limited to 'L-99.lisp')
-rw-r--r-- | L-99.lisp | 54 |
1 files changed, 51 insertions, 3 deletions
@@ -343,13 +343,61 @@ (equal (decode (encode-modified x)) x))) +;; P13 (**) Run-length encoding of a list (direct solution). +(defun encode-direct-1 (x prev n) + (cond + ((endp x) + (cond + ((zp n) nil) + ((equal n 1) (list prev)) + (t (list (list n prev))))) + ((or (zp n) + (equal (car x) prev)) + (encode-direct-1 (cdr x) (car x) (1+ n))) + ((equal n 1) + (cons prev (encode-direct-1 (cdr x) (car x) 1))) + (t (cons (list n prev) + (encode-direct-1 (cdr x) (car x) 1))))) + +(defmacro encode-direct (x) + `(encode-direct-1 ,x nil 0)) + +(defthm app-repeat-1 + (implies (and (natp n) + (consp x)) + (equal (app (repeat (car x) n) x) + (cons (car x) + (app (repeat (car x) n) (cdr x)))))) + +(defthm decode-encode-direct-1 (implies (and (atom-listp x) (atom sym) (natp n)) - (equal (decode (encode-modified-1 x sym n)) + (equal (decode (encode-direct-1 x sym n)) (app (repeat sym n) x)))) -(defthm decode-encode-mofified +(defthm decode-encode-direct (implies (atom-listp x) - (equal (decode (encode-modified x)) + (equal (decode (encode-direct x)) x))) + +(defthm not-zp-car-repeat + (implies (not (zp n)) + (equal (car (repeat sym n)) sym))) + +(defthm consp-repeat + (implies (posp n) + (consp (repeat x n)))) + +(defthm encode-direct-equal-encode-mofified-1 + (implies (and (atom-listp x) + (atom sym) + (natp n)) + (equal (encode-direct-1 x sym n) + (encode-modified-1 (encode-1 (pack-1 x (repeat sym n))))))) + +(defthm encode-direct-equal-encode-mofified + (implies (atom-listp x) + (equal (encode-direct x) + (encode-modified x)))) + |