什么是遞歸
網(wǎng)站設計、成都做網(wǎng)站的關注點不是能為您做些什么網(wǎng)站,而是怎么做網(wǎng)站,有沒有做好網(wǎng)站,給創(chuàng)新互聯(lián)一個展示的機會來證明自己,這并不會花費您太多時間,或許會給您帶來新的靈感和驚喜。面向用戶友好,注重用戶體驗,一切以用戶為中心。遞歸做為一種算法在程序設計語言中廣泛應用,它是指函數(shù)/過程/子程序在運行過程中直接或間接調(diào)用自身而產(chǎn)生的重入現(xiàn)象。
遞歸算法一般用于解決三類問題:
a.數(shù)據(jù)的定義是按遞歸定義的。(Fibonacci(斐波那契)函數(shù))
b.問題解法按遞歸算法實現(xiàn)。(回溯)
c.數(shù)據(jù)的結構形式是按遞歸定義的。(樹的遍歷,圖的搜索)
例子:
這是一個排列的例子,它所做的工作是將輸入的一個字符串中的所有元素進行排序并輸出
例如:你給出的參數(shù)是”abc” 則程序會輸出: abc acb bac bca cab cba a
算法的出口在于:low=high也就是現(xiàn)在給出的排列元素只有一個時。
算法的逼近過程:先確定排列的第一位元素,也就是循環(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中什么是遞歸的詳細內(nèi)容,更多請關注創(chuàng)新互聯(lián)其它相關文章!