迭代和遞歸的實例 深究遞歸和迭代的區(qū)別,聯(lián)系,優(yōu)缺點及實例對比?
深究遞歸和迭代的區(qū)別,聯(lián)系,優(yōu)缺點及實例對比?區(qū)別與聯(lián)系:遞歸是迭代的特例。理論上,任何遞歸都可以轉化為迭代。優(yōu)缺點及比較:遞歸性能不如迭代,但遞歸思想簡單明了,有時必須用遞歸來做,但迭代做不到。例如
深究遞歸和迭代的區(qū)別,聯(lián)系,優(yōu)缺點及實例對比?
區(qū)別與聯(lián)系:遞歸是迭代的特例。理論上,任何遞歸都可以轉化為迭代。優(yōu)缺點及比較:遞歸性能不如迭代,但遞歸思想簡單明了,有時必須用遞歸來做,但迭代做不到。例如,在實際開發(fā)中,有一個描述實體之間層次關系的表,比如遍歷所有實體之間的層次關系,即N:m的關系,它事先不知道每個實體的個數(shù),所以不能通過迭代來實現(xiàn)。我們必須用遞歸來做深層遞歸才能得到結果。
遞歸和迭代有什么區(qū)別?
遞歸和迭代都是循環(huán)類型。簡單地說,遞歸就是反復調用函數(shù)本身來實現(xiàn)循環(huán)。迭代是由函數(shù)中的某些代碼實現(xiàn)的循環(huán)。迭代與普通循環(huán)的區(qū)別在于,循環(huán)代碼中參與運算的變量也是保存結果的變量,當前保存的結果是下一次循環(huán)計算的初始值。在遞歸循環(huán)中,當滿足終止條件時,循環(huán)將逐層返回。迭代使用計數(shù)器結束循環(huán)。當然,在許多情況下,各種循環(huán)是混合的,這取決于具體的需要。遞歸示例,例如,給定一個整數(shù)數(shù)組,使用半查詢返回數(shù)組中指定值的索引,假設數(shù)組已排序。為了便于描述,假設所有的元素都是正數(shù),數(shù)組的長度是2的整數(shù)倍。半查詢是一種查詢,它比遍歷所有元素快得多。迭代的經(jīng)典例子是實數(shù)的累加,例如計算從1到100的所有實數(shù)之和。
如何區(qū)別遞歸和迭代?
遞歸必須有一些基本情況遞歸調用總是朝著生成基準情況的方向前進
DNS遞歸和迭代的區(qū)別?
1。遞歸查詢:一般來說,客戶端和服務器之間的關系是遞歸查詢,即當客戶端向DNS服務器發(fā)送請求時,如果DNS服務器本身無法解析,則會向另一個DNS服務器發(fā)送一個查詢請求,并將結果交給客戶端。迭代查詢(repeated query):在一般DNS服務器之間屬于迭代查詢。例如,如果dns2不能響應dns1的請求,它會給dns2一個dns3的IP地址,這樣它就可以向dns3發(fā)送一個請求。例如,如果一個學生問老師一個問題,王老師會讓他回答這個問題,這叫做遞歸查詢。在這期間,王先生可能也不會。這時,王先生問張先生,他們之間的查詢叫做迭代查詢
尾遞歸究竟是好是壞?
如果遞歸級別太多,則會出現(xiàn)堆棧溢出異常,因為每次調用都會生成新的堆棧幀,并使用此堆棧幀保留當前函數(shù)的狀態(tài)值。如果不需要保存狀態(tài)值,則可以重用堆棧幀而不會導致堆棧溢出。
以n的階乘為例:
正常遞歸:
如果n=3,則每一步都需要保留n值和下一個函數(shù)的返回值,因此每次調用都需要創(chuàng)建一個新的堆棧幀
尾部遞歸:
如果n=3,則每次調用都可以重用堆棧幀,因為不需要保存狀態(tài)值。
因此,當遞歸在當前堆棧幀執(zhí)行后完成時,它不需要保留當前堆棧幀,但根據(jù)當前堆棧幀的結果,它可以在進入下一個堆棧幀時優(yōu)化為尾部遞歸。通常,尾部遞歸需要滿足遞歸調用是函數(shù)體中最后執(zhí)行的語句。例如,在factorial示例中,要執(zhí)行的最后一條語句是直接調用factorial(n-1,n*result),而不是表達式n*factorial(n-1)。如果是表達式,則需要堆棧幀來保留N和階乘(N-1)的結果。
DNS遞歸和迭代的區(qū)別?
遞歸意味著用戶只向本地DNS服務器發(fā)出請求,然后等待肯定或否定的回答。迭代是本地服務器向根DNS服務器發(fā)出請求,根DNS服務器只給出下一級DNS服務器的地址,然后本地DNS服務器向下一級DNS服務器發(fā)出查詢請求,直到得到最終答案。
dns中遞歸查詢與迭代查詢的區(qū)別?
遞歸查詢是域名服務器將查詢域名而不是客戶端(較低級別的DNS服務器)。如果域名服務器不能直接應答,域名服務器將遞歸查詢域樹中每個分支的頂部和底部,最后將查詢結果返回給客戶端。迭代查詢能夠使其他服務器返回一個最佳查詢點提示或主機地址。如果最佳查詢點包含要查詢的主機地址,則返回主機地址信息。如果此時服務器不能直接查詢主機地址,則會根據(jù)提示進行查詢。2通常,DNS工作站發(fā)出的查詢請求屬于遞歸查詢。一般發(fā)生在客戶端和服務器之間,也有DNS服務器和DNS服務器之間的特殊情況。根DNS服務器應始終使用迭代查詢而不是遞歸查詢。通常,每個指南都會更靠近根服務器(up)。搜索完根域名服務器后,會根據(jù)提示再次向下搜索。三。不同的查詢狀態(tài)是遞歸查詢。在域名服務器的查詢過程中,客戶端將完全處于等待狀態(tài)。迭代查詢直到服務器給出的提示包含要查詢的主機地址。
遞歸與迭代的區(qū)別?
遞歸和迭代都是循環(huán)類型。簡單地說,遞歸就是反復調用函數(shù)本身來實現(xiàn)循環(huán)。迭代是由函數(shù)中的某些代碼實現(xiàn)的循環(huán)。迭代與普通循環(huán)的區(qū)別在于,循環(huán)代碼中參與運算的變量也是保存結果的變量,當前保存的結果是下一次循環(huán)計算的初始值。在遞歸循環(huán)中,當滿足終止條件時,循環(huán)將逐層返回。迭代使用計數(shù)器結束循環(huán)。當然,在許多情況下,各種循環(huán)是混合的,這取決于具體的需要。遞歸示例,例如,給定一個整數(shù)數(shù)組,使用半查詢返回數(shù)組中指定值的索引,假設數(shù)組已排序。為了便于描述,假設所有的元素都是正數(shù),數(shù)組的長度是2的整數(shù)倍。半查詢是一種查詢,它比遍歷所有元素快得多。迭代的經(jīng)典例子是實數(shù)的累加,例如計算從1到100的所有實數(shù)之和。