您好,登錄后才能下訂單哦!
什么是遞歸
遞歸做為一種算法在程序設計語言中廣泛應用,它是指函數/過程/子程序在運行過程中直接或間接調用自身而產生的重入現象。
遞歸算法一般用于解決三類問題:
a.數據的定義是按遞歸定義的。(Fibonacci(斐波那契)函數)
b.問題解法按遞歸算法實現。(回溯)
c.數據的結構形式是按遞歸定義的。(樹的遍歷,圖的搜索)
例子:
這是一個排列的例子,它所做的工作是將輸入的一個字符串中的所有元素進行排序并輸出
例如:你給出的參數是”abc” 則程序會輸出: abc acb bac bca cab cba a
算法的出口在于:low=high也就是現在給出的排列元素只有一個時。
算法的逼近過程:先確定排列的第一位元素,也就是循環中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中什么是遞歸的詳細內容,更多請關注億速云其它相關文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。