欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java遞歸算法詳解(動力節(jié)點整理)

 更新時間:2017年03月29日 16:48:07   投稿:mrr  
Java遞歸算法是基于Java語言實現(xiàn)的遞歸算法。遞歸算法對解決一大類問題很有效,它可以使算法簡潔和易于理解。接下來通過本文給大家介紹Java遞歸算法相關(guān)知識,感興趣的朋友一起學(xué)習(xí)吧

遞歸算法是一種直接或者間接調(diào)用自身函數(shù)或者方法的算法。Java遞歸算法是基于Java語言實現(xiàn)的遞歸算法。遞歸算法的實質(zhì)是把問題分解成規(guī)??s小的同類問題的子問題,然后遞歸調(diào)用方法來表示問題的解。遞歸算法對解決一大類問題很有效,它可以使算法簡潔和易于理解。

   遞歸算法解決問題的特點:

    1)遞歸就是方法里調(diào)用自身。

  2) 在使用遞增歸策略時,必須有一個明確的遞歸結(jié)束條件,稱為遞歸出口。

  3)遞歸算法解題通常顯得很簡潔,但遞歸算法解題的運行效率較低。所以一般不提倡用遞歸算法設(shè)計程序。

  4)在遞歸調(diào)用的過程當(dāng)中系統(tǒng)為每一層的返回點、局部量等開辟了棧來存儲。遞歸次數(shù)過多容易造成棧溢出等,所以一般不提倡用遞歸算法設(shè)計程序。

 遞歸算法所體現(xiàn)的“重復(fù)”一般有三個要求:

  一是每次調(diào)用在規(guī)模上都有所縮小(通常是減半);

  二是相鄰兩次重復(fù)之間有緊密的聯(lián)系,前一次要為后一次做準(zhǔn)備(通常前一次的輸出就作為后一次的輸入);

  三是在問題的規(guī)模極小時必須用直接給出解答而不再進行遞歸調(diào)用,因而每次遞歸調(diào)用都是有條件的(以規(guī)模未達到直接解答的大小為條件),無條件遞歸調(diào)用將會成為死循環(huán)而不能正常結(jié)束。

    為了理解遞歸算法,現(xiàn)舉一個實例說明如下:

        問題描述:

求解Fibonacci數(shù)列的第10個位置的值?(斐波納契數(shù)列(Fibonacci Sequence),又稱黃金分割數(shù)列,指的是這樣一個數(shù)列:1、1、2、3、5、8、13、21、……在數(shù)學(xué)上,斐波納契數(shù)列以如下被以遞歸的方法定義:F0=0,F(xiàn)1=1,F(xiàn)n=F(n-1)+F(n-2)(n>=2,n∈N*))

       Java代碼清單:

package com.bjpowernode.test; 
 
 public classFab { 
 
 public static void main(String args[]){ 
 System.out.println(fab(5)); 
 } 
 private static int fab(int index){ 
 if(index==1 || index==2){ 
  return 1; 
 }else{ 
  return fab(index-1)+fab(index-2); 
 } 
 } 
 } 

        程序分析:

                這個實例是非常經(jīng)典的實例,主要是利用遞歸實現(xiàn)了Fibonacci數(shù)列。這個遞歸算法的出口是在

 if(index==1 || index==2){ 
 return 1; 
 }

              這個代碼段上,如果程序的index符合條件就會停止進行遞歸。所以這個程序的運行流程是:

程序分析到這里,遞歸的實現(xiàn)也就完成了,讀者可以自己簡單的做個demo,感受一下這個算法的精妙之處,其實很多人都在說算法難,難于上青天,其實掌握算法的根才是最重要的,什么是算法的根呢,就拿這個遞歸算法來說吧,我感覺這個根就是那個出口,只要找到這個出口所在,那么算法自然而然就能水到渠成了。

以上所述是小編給大家介紹的Java遞歸算法詳解(動力節(jié)點整理),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • @Transactional注解異常報錯之多數(shù)據(jù)源詳解

    @Transactional注解異常報錯之多數(shù)據(jù)源詳解

    這篇文章主要介紹了@Transactional注解異常報錯之多數(shù)據(jù)源詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 淺析Java中為什么要設(shè)計包裝類

    淺析Java中為什么要設(shè)計包裝類

    我們知道Java是一個面相對象的編程語言,基本類型并不具有對象的性質(zhì),為了讓基本類型也具有對象的特征,就出現(xiàn)了包裝類型,它相當(dāng)于將基本類型“包裝起來”,使得它具有了對象的性質(zhì),并且為其添加了屬性和方法,豐富了基本類型的操作
    2021-06-06
  • Spring Boot2如何構(gòu)建可部署的war包

    Spring Boot2如何構(gòu)建可部署的war包

    這篇文章主要介紹了Spring Boot2如何構(gòu)建可部署的war包,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • Java圖形化界面設(shè)計之布局管理器之BorderLayout案例詳解

    Java圖形化界面設(shè)計之布局管理器之BorderLayout案例詳解

    這篇文章主要介紹了Java圖形化界面設(shè)計之布局管理器之BorderLayout案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Java遞歸實現(xiàn)斐波那契數(shù)列

    Java遞歸實現(xiàn)斐波那契數(shù)列

    這篇文章主要為大家詳細(xì)介紹了Java遞歸實現(xiàn)斐波那契數(shù)列,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • java中JSONArray互相轉(zhuǎn)換List的實現(xiàn)

    java中JSONArray互相轉(zhuǎn)換List的實現(xiàn)

    本文主要介紹了java中JSONArray互相轉(zhuǎn)換List的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 使用java實現(xiàn)備份和恢復(fù)SQLServer表數(shù)據(jù)

    使用java實現(xiàn)備份和恢復(fù)SQLServer表數(shù)據(jù)

    這篇文章主要為大家詳細(xì)介紹了如何使用java實現(xiàn)備份和恢復(fù)SQLServer表數(shù)據(jù),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • mybatis-plus多表分頁查詢最佳實現(xiàn)方法(非常簡單)

    mybatis-plus多表分頁查詢最佳實現(xiàn)方法(非常簡單)

    這篇文章主要給大家介紹了關(guān)于mybatis-plus多表分頁查詢最佳實現(xiàn)方法,文中介紹的方法非常簡單,MyBatis-Plus中分頁查詢是比較方便的,這個功能在網(wǎng)站中也是非常常用的,這方面的知識點是必備的知識點,需要的朋友可以參考下
    2023-08-08
  • SpringBoot?thymeleaf實現(xiàn)餅狀圖與柱形圖流程介紹

    SpringBoot?thymeleaf實現(xiàn)餅狀圖與柱形圖流程介紹

    這篇文章主要介紹了SpringBoot?thymeleaf實現(xiàn)餅狀圖與柱形圖流程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12
  • 基于SpringBoot+Redis的Session共享與單點登錄詳解

    基于SpringBoot+Redis的Session共享與單點登錄詳解

    這篇文章主要介紹了基于SpringBoot+Redis的Session共享與單點登錄,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07

最新評論