type
status
date
slug
summary
tags
category
icon
password
Property
Jul 13, 2023 01:59 PM
Recursion 递归
Video
Review
data:image/s3,"s3://crabby-images/3bde7/3bde79ac774a80ca27e5d1140bc972031e749353" alt="notion image"
data:image/s3,"s3://crabby-images/06a50/06a5098394608e4583287b920a429836dfcade5e" alt="notion image"
data:image/s3,"s3://crabby-images/d08b9/d08b9c7531c1ea35d44253f95f4a64ff0c0cf13c" alt="notion image"
data:image/s3,"s3://crabby-images/8b501/8b50150a33ad445e197a373cbd10f0741c84106d" alt="notion image"
example :打印素数的函数
Recursion
data:image/s3,"s3://crabby-images/e7da1/e7da12925fd80bf65a1abfab6508c6c3a5608743" alt="notion image"
data:image/s3,"s3://crabby-images/e768f/e768ff8241d420a690dbb40c90c415110eeabe3e" alt="notion image"
data:image/s3,"s3://crabby-images/33864/338647df5e0692a907d68800659f1e948f2f5c0d" alt="notion image"
递归对于解决具有自然重复结构的问题很有用,它们是根据自身定义的
data:image/s3,"s3://crabby-images/e090b/e090b6adf24be7455bf112f57519228b9877e913" alt="notion image"
比如:DNS 查询
data:image/s3,"s3://crabby-images/85e54/85e54060a94035bfda87ebb3df30ea1f7aec8bff" alt="notion image"
这也是某种意义上的递归,直到 获取函数的结果
Recursive Function
递归函数
data:image/s3,"s3://crabby-images/e6d02/e6d02f77d1441367992f9d0756d34e11b70655b8" alt="notion image"
data:image/s3,"s3://crabby-images/e61ac/e61ac6f7f5245a8802063deaca6430ba4a9319cc" alt="notion image"
data:image/s3,"s3://crabby-images/5cc1d/5cc1d2840eb89baaec6b864b0ab7897111cbb8bb" alt="notion image"
逐渐的将问题缩小,直到缩到最小,缩小到最小,很容得出结果,这样问题就解决了。
data:image/s3,"s3://crabby-images/40331/40331a3370ab963bbd6b9a05e744a8d6679f4766" alt="notion image"
data:image/s3,"s3://crabby-images/be697/be697f571ceb739e491e14ade8cd4b9f40644c75" alt="notion image"
重在抽象,找到重复的部分
data:image/s3,"s3://crabby-images/a69e5/a69e5d71dddbedf3b7d1aa5905ebba23696513a7" alt="notion image"
函数抽象:不要担心阶乘是递归的,只要假设阶乘得到正确的答案
Visualizing Recursion
data:image/s3,"s3://crabby-images/a3221/a32216dacaa6cdd8212daf1fa738b7b7e1843234" alt="notion image"
data:image/s3,"s3://crabby-images/845d8/845d85f6b87c7e53c7343dfaf66afff29ab70123" alt="notion image"
先递到最后一层,再逐渐的归回去
data:image/s3,"s3://crabby-images/4a94f/4a94fdbbc4d1214b6473e44835b9b12d8b42cdf3" alt="notion image"
data:image/s3,"s3://crabby-images/8d8c4/8d8c47e1984c907788ae1750915ff56ff794ce76" alt="notion image"
data:image/s3,"s3://crabby-images/29da6/29da6c12b09a316b1369e692209a4e4438e94625" alt="notion image"
data:image/s3,"s3://crabby-images/e12ea/e12ea9a554be85d213de82003698a7ddf10bc899" alt="notion image"
data:image/s3,"s3://crabby-images/4c5a9/4c5a95f2912e05a53baa20e9451fd7042c43bc52" alt="notion image"
How To Trust Functional Abstraction
data:image/s3,"s3://crabby-images/9baeb/9baeb7729bb60f50051f5191565d9b910a0f7f38" alt="notion image"
基准的验证,并且,更大规模的计算是基于基础验证的
data:image/s3,"s3://crabby-images/ddc2d/ddc2df4193943683852fa5b152e8c9e871a24229" alt="notion image"
Identifying Patterns
data:image/s3,"s3://crabby-images/63a78/63a78ffa6cf6d29c5e5e254b5d7520402eab1d82" alt="notion image"
这个例子中,递归并不是一个hof,因为返回的不是函数,而是函数的调用结果
Example
data:image/s3,"s3://crabby-images/2744c/2744c4f1e49d74ba15f298d46b6eb6288527e938" alt="notion image"
data:image/s3,"s3://crabby-images/11021/110218a16f8e90e1d9a47c9dd1df76faf8e4bf91" alt="notion image"
data:image/s3,"s3://crabby-images/a3565/a356520239e4f78c365ca1ea5d75c43490b01fca" alt="notion image"
data:image/s3,"s3://crabby-images/2f677/2f677699d9efb3780a8010ca26e50fb076832863" alt="notion image"
这种形式也是可以的,base case不是那么的具体,明显
Sum Digits
data:image/s3,"s3://crabby-images/50d1c/50d1cea2de87b876a6bc9f3b6063625c283c9466" alt="notion image"
data:image/s3,"s3://crabby-images/109eb/109eb466d26a10b402396d7cce0524ad19b86074" alt="notion image"
data:image/s3,"s3://crabby-images/dd02f/dd02f601e6cb7f0978a8cf4bcc50d8c83afce12b" alt="notion image"
可以利用整除和区域来做
data:image/s3,"s3://crabby-images/95be4/95be4510df8223fa8040eaf015e0a211ada3434f" alt="notion image"
data:image/s3,"s3://crabby-images/88f5e/88f5e1b1024c206d349408612181417557fe4365" alt="notion image"
Summary
data:image/s3,"s3://crabby-images/c70a5/c70a519f49d63bd91ce10b9c207e327107f51db6" alt="notion image"
- 作者:Kitety
- 链接:https://www.kitety.com/article/cs-61a-6
- 声明:本文采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处。
相关文章