分享 关于递归

yfractal · May 08, 2014 · Last by leozwa replied at May 09, 2014 · 3265 hits

  1. 递归有用吗? 觉得 web 开发里面递归并不多。 算法种似乎有很多递归(对算法了解的不多),比如树,图,链表。觉得理解了递归,这些就比较容易理解了。 递归能写出很舒服的程序,比如说 小清新

  2. 如何理解递归?

    #+BEGIN_SRC ruby
     def fact(n)
       if n == 1
         return 1
       end
       return n * fact(n-1)
     end
    #+END_SRC
    
  3. 求证最基本的情况是否成立

  4. 把 fact(n-1) 当成一种功能的抽象

  5. 假设 fact(n-1) 是正确的

  6. 求证 fact(n) 是否正确,在假设 f(n-1) 正确的前提下

....

  1. Verify the base case.
  2. Treat fact(n-1) as a functional abstraction!
  3. Assume that fact(n-1) is correct.
  4. Verify that fact(n) is correct, assuming that fact(n-1) correct.

当然把递归当成数学的递推来理解,也很不错。

简单的题目

#+BEGIN_SRC ruby
 # [fib数列](http://zh.wikipedia.org/zh-cn/%E6%96%90%E6%B3%A2%E9%82%A3%E5%A5%91%E6%95%B0%E5%88%97)
  nth_fib(1) == 1
  nth_fib(2) == 1
  nth_fib(3) == 2
  nth_fib(10) == 55

  # 判断一个字符串是否为回文
  huiwen("a") == true
  huiwen("abba") == true
  huiwen("abcba") == true
  huiwen("abca") == false


  # count_change
  # 假设有不同种的硬币比如1元,2元,5元
  # 然后给出一个钱数,比如30,求有多少种找钱的可能

  coin_kinds=[50, 25, 10, 5, 1]
  # Return the number of ways to change amount a using coin kinds.
  count_change(30) == 18
  count_change(5)
  count_change(1) == 1
  count_change(0) == 1
#+END_SRC

递归还有很多好玩的东西,比如尾递归,比如把递归编程循环之类的。

以上只是简单的翻译,均参考与以下链接。 https://inst.eecs.berkeley.edu/~cs61a/fa12/slides/20-Recursion_1pps.pdf https://inst.eecs.berkeley.edu/~cs61a/fa12/slides/21.py

若要理解递归,先要理解递归

二楼说的对

你们两个不叫递归,最多算个 deadlock

一楼永远理解不了,二楼栈溢出了

@zackteng 哈哈哈。其实一楼的说法没错。

You need to Sign in before reply, if you don't have an account, please Sign up first.