您好,登錄后才能下訂單哦!
什么是遞歸
遞歸做為一種算法在程序設(shè)計(jì)語(yǔ)言中廣泛應(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)容,更多請(qǐng)關(guān)注億速云其它相關(guān)文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。