当前位置:网站首页>遞迴思想的巧妙理解
遞迴思想的巧妙理解
2020-11-06 01:35:38 【itread01】
邏輯是數學的少年時代,數學是邏輯的成年時代。
——羅素
“遞迴”
這是在程式、演算法設計中的基礎和重中之重。當初理解這一點我也花費了不少時間,對於初學者來說,如何生動形象的展現著一過程,成了理解這一思想的關鍵。
這篇博文的來由,源於同學問我的一個問題:
我一看啊,這波,這波是明顯的遞迴啊!!
我想著,怎麼解釋呢,於是開啟百度搜索遞迴:
定義
程式呼叫自身的程式設計技巧稱為遞迴( recursion)。遞迴做為一種演算法在程式設計語言中廣泛應用。 一個過程或函式在其定義或說明中有直接或間接呼叫自身的一種方法,它通常把一個大型複雜的問題層層轉化為一個與原問題相似的規模較小的問題來求解,遞迴策略只需少量的程式就可描述出解題過程所需要的多次重複計算,大大地減少了程式的程式碼量。遞迴的能力在於用有限的語句來定義物件的無限集合。一般來說,遞迴需要有邊界條件、遞迴前進段和遞迴返回段。當邊界條件不滿足時,遞迴前進;當邊界條件滿足時,遞迴返回。
我想這,這麼生硬的解釋,還是別麻煩人家了吧,於是這個解釋就鴿了好幾天
奇思妙想
某個摸魚的晚上,我突然想到了一個解釋遞迴生動形象的例子,那就是:
俄羅斯套娃!!
那麼,如何用俄羅斯套娃的思想去理解遞迴思想呢?
又是眾所周知,遞迴其實就是程式呼叫自身,這不就好像是,在自己肚子裡面裝了一個自己麼?
不過,我們開這個套娃的方式,得遵循以下規則;
先吧套娃的上半部分拿走(執行呼叫自身的函式上邊的程式碼);
繼續拿上半部分,直到拿出了一個不能在開的娃(遞迴到底);
看看這個不能再套娃的娃(完整的執行這個最“深”的函式);
在依次拿出所有套娃的下半身(自底向上執行所有遞迴函式的下半部分)。
案例解釋
我們先看這個求樹的深度的程式碼:
int TreeDepth(BT *T){
int ld=0,rd=0;
if(T==NULL) return 0;
else{
ld=TreeDepth(T->lchild);
rd=TreeDepth(T->rchild);
if(ld>rd)
return ld+1;
else
return rd+1;
}
}
我就畫個圖來看看吧
假設有這麼一顆樹,BT是函式中指標*T所在位置
我們執行這一段程式碼
int TreeDepth(BT *T){
int ld=0,rd=0;
if(T==NULL) return 0;
else{
ld=TreeDepth(T->lchild);
先遞迴到底邊,在走下去,全是NULL了,就可以執行後一段程式碼
if(ld>rd)
return ld+1;
else
return rd+1;
當然,這裡ld和rd都是0,返回值是1,根據
ld=TreeDepth(T->lchild);
則上一層函式的ld=1
我們繼續看,因為這一個函式已經執行結束了,我們來執行上一個函式的後半段程式碼。
rd=TreeDepth(T->rchild);
if(ld>rd)
return ld+1;
else
return rd+1;
}
}
這裡我們發現,可以一直走右子樹走下去,參考上一步的操作,以此類推,我們得到下圖
再繼續推下去,整個程式的返回值就一目瞭然了
這裡還是要再提一下深度優先搜尋(DFS),眾所周知深搜的最基本技巧就是遞迴。
PS:雖然深搜也可以用棧實現,不過遞迴就是程式自己調出棧來儲存資料,差別不大。
樹是特殊的圖,樹的遍歷也是圖的遍歷,這種按照深度一口氣遍歷下來的方式,就是我們所謂的DFS,再樹基礎的學習過程中,我們也可以體會到很多圖的性質
希望我的拋磚引玉能引起更多的思考
版权声明
本文为[itread01]所创,转载请带上原文链接,感谢
https://www.itread01.com/content/1604563565.html
边栏推荐
- C++ 数字、string和char*的转换
- C++学习——centos7上部署C++开发环境
- C++学习——一步步学会写Makefile
- C++学习——临时对象的产生与优化
- C++学习——对象的引用的用法
- C++编程经验(6):使用C++风格的类型转换
- Won the CKA + CKS certificate with the highest gold content in kubernetes in 31 days!
- C + + number, string and char * conversion
- C + + Learning -- capacity() and resize() in C + +
- C + + Learning -- about code performance optimization
猜你喜欢
-
C + + programming experience (6): using C + + style type conversion
-
Latest party and government work report ppt - Park ppt
-
在线身份证号码提取生日工具
-
Online ID number extraction birthday tool
-
️野指针?悬空指针?️ 一文带你搞懂!
-
Field pointer? Dangling pointer? This article will help you understand!
-
HCNA Routing&Switching之GVRP
-
GVRP of hcna Routing & Switching
-
Seq2Seq实现闲聊机器人
-
【闲聊机器人】seq2seq模型的原理
随机推荐
- LeetCode 91. 解码方法
- Seq2seq implements chat robot
- [chat robot] principle of seq2seq model
- Leetcode 91. Decoding method
- HCNA Routing&Switching之GVRP
- GVRP of hcna Routing & Switching
- HDU7016 Random Walk 2
- [Code+#1]Yazid 的新生舞会
- CF1548C The Three Little Pigs
- HDU7033 Typing Contest
- HDU7016 Random Walk 2
- [code + 1] Yazid's freshman ball
- CF1548C The Three Little Pigs
- HDU7033 Typing Contest
- Qt Creator 自动补齐变慢的解决
- HALCON 20.11:如何处理标定助手品质问题
- HALCON 20.11:标定助手使用注意事项
- Solution of QT creator's automatic replenishment slowing down
- Halcon 20.11: how to deal with the quality problem of calibration assistant
- Halcon 20.11: precautions for use of calibration assistant
- “十大科学技术问题”揭晓!|青年科学家50²论坛
- "Top ten scientific and technological issues" announced| Young scientists 50 ² forum
- 求反转链表
- Reverse linked list
- js的数据类型
- JS data type
- 记一次文件读写遇到的bug
- Remember the bug encountered in reading and writing a file
- 单例模式
- Singleton mode
- 在这个 N 多编程语言争霸的世界,C++ 究竟还有没有未来?
- In this world of N programming languages, is there a future for C + +?
- es6模板字符
- js Promise
- js 数组方法 回顾
- ES6 template characters
- js Promise
- JS array method review
- 【Golang】️走进 Go 语言️ 第一课 Hello World
- [golang] go into go language lesson 1 Hello World