美文网首页
我们都爱尾递归

我们都爱尾递归

作者: Tulayang | 来源:发表于2015-04-22 10:16 被阅读149次

一个女服务生走向有四个客人的桌子。“你们要什么?” 她问。“我要特餐,” 第一个客人说。 “我也是,” 第二个客人说。“听起来不错,” 第三个客人说。每个人看着第四个客人。 “我要一个香菜蛋奶酥,” 他小声地说。瞬息之间,女服务生就转身踩着高跟鞋走回柜台去了。“三个特餐”,她大声对厨师说,“还有一个香菜蛋奶酥。”

; Sequence: 
;
; (1 1 1 0 1 0 0 0 0 1) => ((3 1) 0 1 (4 0) 1)
;
; →     1 1 1 0 1 0 0 0 0 1
; →  1    1 1 0 1 0 0 0 0 1
; →  2,1    1 0 1 0 0 0 0 1
; →  3,1      0 1 0 0 0 0 1
; →  3,1 0      1 0 0 0 0 1
; →  3,1 0 1      0 0 0 0 1
; →  3,1 0 1 0      0 0 0 1
; →  3,1 0 1 2,0      0 0 1
; →  3,1 0 1 3,0        0 1
; →  3,1 0 1 4,0          1
; →  3,1 0 1 4,0 1         
;
; Procedure: 
; 
; seq                  n  x  last-seq
; ()                   1  1  (1 1 0 1 0 0 0 0 1)
; ()                   2  1    (1 0 1 0 0 0 0 1)
; ()                   3  1      (0 1 0 0 0 0 1)
; ((3 1))              1  0        (1 0 0 0 0 1)
; ((3 1) 0)            1  1          (0 0 0 0 1)
; ((3 1) 0 1)          1  0            (0 0 0 1)
; ((3 1) 0 1)          2  0              (0 0 1)
; ((3 1) 0 1)          3  0                (0 1)
; ((3 1) 0 1)          4  0                  (1)
; ((3 1) 0 1 (4 0))    1  1                   ()
; ((3 1) 0 1 (4 0) 1)  1  1                   ()
;
; Sequence: 
;
; ((3 1) 0 1 (3 0) 0 1) => (1 1 1 0 1 0 0 0 0 1)
;
; Procedure: 
;
; seq                   it    last-seq
; (1 1 1)               (3 1) (0 1 (4 0) 1)
; (1 1 1 0)             0       (1 (4 0) 1)
; (1 1 1 0 1)           1         ((4 0) 1)
; (1 1 1 0 1 0 0 0 0)   (4 0)           (1)
; (1 1 1 0 1 0 0 0 0 1) 1                ()

                   
(define it-n
  (lambda (x n)
    (if (> n 1)
      (list (list n x)) ; ((3 1))
      (list x))))       ; (1)

(define compare
  (lambda (seq last-seq n x)
    (if (eq? last-seq '())
      (append seq (it-n x n))
      (let ((i (car last-seq)))
        (if (= x i)
          (compare seq (cdr last-seq) (+ n 1) i)  
          (compare (append seq (it-n x n)) (cdr last-seq) 1 i))))))

(define compress
  (lambda (seq)
    (if (list? seq)
      (compare '() (cdr seq) 1 (car seq))
      seq)))

(define unof
  (lambda (lst n x)
    (if (> n 0)
      (unof (append lst (list x)) (- n 1) x)
      lst)))                                 

(define unlice
  (lambda (seq it last-seq)
    (if (eq? last-seq '())
      (if (list? it)
        (let ((n (car it)) (x (car (cdr it))))
          (append seq (unof '() n x)))
        (append seq (list it)))
      (if (list? it)
        (let ((n (car it)) (x (car (cdr it))))
          (unlice (append seq (unof '() n x)) (car last-seq) (cdr last-seq)))
        (unlice (append seq (list it)) (car last-seq) (cdr last-seq))))))

(define uncompress
  (lambda (seq)
    (if (list? seq)
      (unlice '() (car seq) (cdr seq))
      seq)))

; (1 1 1 0 1 0 0 0 0 1) => ((3 1) 0 1 (3 0) 0 1)
(display "(1 1 1 0 1 0 0 0 0 1) => ") 
(display (compress '(1 1 1 0 1 0 0 0 0 1)))
(newline)
; ((3 1) 0 1 (3 0) 0 1) => (1 1 1 0 1 0 0 0 0 1)
(display "((3 1) 0 1 (3 0) 0 1) => ")
(display (uncompress '((3 1) 0 1 (3 0) 0 1)))
(newline)
; (0 0 1 0 1 0 0 0 0 0 0) => ((2 0) 1 0 1 (6 0)) 
(display "(0 0 1 0 1 0 0 0 0 0 0) => ")
(display (compress '(0 0 1 0 1 0 0 0 0 0 0)))
(newline)
; ((2 0) 1 0 1 (6 0)) => (0 0 1 0 1 0 0 0 0 0 0)
(display "((2 0) 1 0 1 (6 0)) => ")
(display (uncompress '((2 0) 1 0 1 (6 0))))

相关文章

  • 我们都爱尾递归

    一个女服务生走向有四个客人的桌子。“你们要什么?” 她问。“我要特餐,” 第一个客人说。 “我也是,” 第二个客人...

  • Kotlin语言(九):特性

    1、尾递归优化 尾递归:函数在调用自己之后没有再执行其他任何操作就是尾递归 尾递归优化的原理就是将递归转换成迭代,...

  • 递归&尾递归

    调用栈的特点,先进后出, FILO, 场景还原。 递归 有栈溢出的可能 stack overflow 尾递归 编译...

  • 递归调用优化

    尾递归优化 函数调用自身,称为递归。如果尾调用自身,就称为尾递归。 递归非常耗费内存,因为需要同时保存成千上百个调...

  • 什么是尾调用?什么是尾递归?尾调用的优化?尾递归优化?

    尾调用优化 尾递归(尾调用优化)

  • C++ 递归算法

    递归算法,尾递归算法求阶乘!

  • 25.尾递归优化

    1.代码如下: 只有尾递归才能优化 1.需要将递归转化为尾递归2.加上关键字tailrec 2.尾递归的原理,看编...

  • python3 尾递归优化装饰器

    python3中没有进行尾递归优化,但是我们可以实现通过一个装饰器实现尾递归优化。 网上常见的尾递归装饰器是基于P...

  • 尾调用优化

    尾调用优化 尾递归 正常递归 尾递归 改写以上代码,使其只有一个参数: 总结一下,递归本质上是一种循环操作。纯粹的...

  • 斐波那茨数列的几种解法

    首先关于尾递归递归:你先帮我把下面搞定,撇准好我再来尾递归:我直接先上再说 用尾递归写费波纳茨数列 用快速幂+矩阵...

网友评论

      本文标题:我们都爱尾递归

      本文链接:https://www.haomeiwen.com/subject/mjmufttx.html