您好,登錄后才能下訂單哦!
這篇文章主要介紹了java如何測試遞歸與循環,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
測試遞歸與循環(這里用for)的執行效率與系統開銷,首先貼出實例問題:實現Fibonacci數列F(n)=F(n-1)+ F(n-2)
測試環境 Eclipse
1.首先我們用遞歸來實現
package com.youfeng.test; public class Fab {//遞歸 public static void main(String [] args){ System.out.println(F(40)); } public static Long F(int index){ if(index==1||index==2){ return 1L; } else{ return F(index-1)+F(index-2); } } }
2.用for循環實現
package com.youfeng.test; public class Fab2 {//循環 public static void main(String [] args){ System.out.println(F(40)); } public static Long F(int index){ if(index==1||index==2){ return 1L; } else{ Long f1=1L; Long f2=1L; Long f=0L; for(int i=0;i<index;i++){ f1=f2; f2=f; f=f1+f2; } return f; } } }
當index的值很小的時候,我們分別執行沒什么區別,執行速度我們感覺不到什么差別,但是當你把index調到足夠大時100 、200、300、1000…… for循環輕松搞定執行速度挺快。
當使用遞歸時,你會發現明顯的卡機 卡機 ,有木有?調用系統資源管理器看看你的系統開銷吧(很可能你你打不開資源管理器,因為你卡機了)。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“java如何測試遞歸與循環”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。