web后端開發(fā)學(xué)什么 遞歸和迭代有什么區(qū)別?
遞歸和迭代有什么區(qū)別?遞歸和迭代都是循環(huán)類型。簡單地說,遞歸就是反復(fù)調(diào)用函數(shù)本身來實(shí)現(xiàn)循環(huán)。迭代是由函數(shù)中的某些代碼實(shí)現(xiàn)的循環(huán)。迭代與普通循環(huán)的區(qū)別在于,循環(huán)代碼中參與運(yùn)算的變量也是保存結(jié)果的變量,當(dāng)
遞歸和迭代有什么區(qū)別?
遞歸和迭代都是循環(huán)類型。簡單地說,遞歸就是反復(fù)調(diào)用函數(shù)本身來實(shí)現(xiàn)循環(huán)。迭代是由函數(shù)中的某些代碼實(shí)現(xiàn)的循環(huán)。迭代與普通循環(huán)的區(qū)別在于,循環(huán)代碼中參與運(yùn)算的變量也是保存結(jié)果的變量,當(dāng)前保存的結(jié)果是下一次循環(huán)計(jì)算的初始值。在遞歸循環(huán)中,當(dāng)滿足終止條件時,循環(huán)將逐層返回。迭代使用計(jì)數(shù)器結(jié)束循環(huán)。當(dāng)然,在許多情況下,各種循環(huán)是混合的,這取決于具體的需要。遞歸示例,例如,給定一個整數(shù)數(shù)組,使用半查詢返回?cái)?shù)組中指定值的索引,假設(shè)數(shù)組已排序。為了便于描述,假設(shè)所有的元素都是正數(shù),數(shù)組的長度是2的整數(shù)倍。半查詢是一種查詢,它比遍歷所有元素快得多。迭代的經(jīng)典例子是實(shí)數(shù)的累加,例如計(jì)算從1到100的所有實(shí)數(shù)之和。
深究遞歸和迭代的區(qū)別,聯(lián)系,優(yōu)缺點(diǎn)及實(shí)例對比?
區(qū)別與聯(lián)系:遞歸是迭代的特例。理論上,任何遞歸都可以轉(zhuǎn)化為迭代。優(yōu)缺點(diǎn)及比較:遞歸性能不如迭代,但遞歸思想簡單明了,有時必須用遞歸來做,但迭代做不到。例如,在實(shí)際開發(fā)中,有一個描述實(shí)體之間層次關(guān)系的表,比如遍歷所有實(shí)體之間的層次關(guān)系,即N:m的關(guān)系,它事先不知道每個實(shí)體的個數(shù),所以不能通過迭代來實(shí)現(xiàn)。我們必須用遞歸來做深層遞歸才能得到結(jié)果。
DNS遞歸和迭代的區(qū)別?
1. 遞歸查詢:客戶端和服務(wù)器之間的一般關(guān)系是遞歸查詢,即當(dāng)客戶端向DNS服務(wù)器發(fā)送請求時,如果DNS服務(wù)器本身無法解析,則會向另一個DNS服務(wù)器發(fā)送查詢請求,并將結(jié)果傳輸給客戶端。迭代查詢(repeated query):DNS服務(wù)器之間的一般關(guān)系是迭代查詢,例如:如果dns2不能響應(yīng)dns1的請求,例如,如果一個學(xué)生問老師一個問題,王先生告訴他答案,他們之間的關(guān)系稱為遞歸查詢。在這期間,王先生可能也不會。這時,王先生問張先生,他們之間的查詢叫做迭代查詢
如何區(qū)別遞歸和迭代?
遞歸必須有一些基準(zhǔn)案例。遞歸調(diào)用總是朝著生成基準(zhǔn)用例的方向前進(jìn)
遞歸和迭代是一種循環(huán)。簡單地說,遞歸就是反復(fù)調(diào)用函數(shù)本身來實(shí)現(xiàn)循環(huán)。迭代是由函數(shù)中的某些代碼實(shí)現(xiàn)的循環(huán)。迭代與普通循環(huán)的區(qū)別在于,循環(huán)代碼中參與運(yùn)算的變量也是保存結(jié)果的變量,當(dāng)前保存的結(jié)果是下一次循環(huán)計(jì)算的初始值。在遞歸循環(huán)中,當(dāng)滿足終止條件時,循環(huán)將逐層返回。迭代使用計(jì)數(shù)器結(jié)束循環(huán)。當(dāng)然,在許多情況下,各種循環(huán)是混合的,這取決于具體的需要。遞歸示例,例如,給定一個整數(shù)數(shù)組,使用半查詢返回?cái)?shù)組中指定值的索引,假設(shè)數(shù)組已排序。為了便于描述,假設(shè)所有的元素都是正數(shù),數(shù)組的長度是2的整數(shù)倍。半查詢是一種查詢,它比遍歷所有元素快得多。迭代的經(jīng)典例子是實(shí)數(shù)的累加,例如計(jì)算從1到100的所有實(shí)數(shù)之和。