什么是遞歸
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了工農(nóng)免費(fèi)建站歡迎大家使用!
遞歸做為一種算法在程序設(shè)計(jì)語言中廣泛應(yīng)用,它是指函數(shù)/過程/子程序在運(yùn)行過程中直接或間接調(diào)用自身而產(chǎn)生的重入現(xiàn)象。
遞歸算法一般用于解決三類問題:
a.數(shù)據(jù)的定義是按遞歸定義的。(Fibonacci(斐波那契)函數(shù))
b.問題解法按遞歸算法實(shí)現(xiàn)。(回溯)
c.數(shù)據(jù)的結(jié)構(gòu)形式是按遞歸定義的。(樹的遍歷,圖的搜索)
例子:
這是一個(gè)排列的例子,它所做的工作是將輸入的一個(gè)字符串中的所有元素進(jìn)行排序并輸出
例如:你給出的參數(shù)是”abc” 則程序會(huì)輸出: abc acb bac bca cab cba a
算法的出口在于:low=high也就是現(xiàn)在給出的排列元素只有一個(gè)時(shí)。
算法的逼近過程:先確定排列的第一位元素,也就是循環(huán)中i所代表的元素, 然后low+1開始減少排列元素,如此下去,直到low=high
示例如下:
public class Foo { public static void main(String[] args) { permute(“abc”); } public static void permute(String str) { char[] strArray = str.toCharArray(); permute(strArray, 0, strArray.length – 1); } public static void permute(char[] list, int low, int high) { int i; if (low == high) { String cout = “”; for (i = 0; i <= high; i++){ cout += list[i]; System.out.println(cout); } }else { for (i = low; i <= high; i++) { char temp = list[low]; list[low] = list[i]; list[i] = temp; permute(list, low + 1, high); temp = list[low]; list[low] = list[i]; list[i] = temp; } } } }
以上就是java中什么是遞歸的詳細(xì)內(nèi)容,更多請關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!