對(duì)于斐波那契數(shù),若是采用遞歸的算法,每個(gè)遞歸調(diào)用都將觸發(fā)另外兩個(gè)遞歸調(diào)用,而這兩個(gè)中調(diào)用任意一個(gè)還會(huì)觸發(fā)另外兩個(gè)的調(diào)用。遞歸調(diào)用的時(shí)間復(fù)雜度O(2^N),空間復(fù)雜度為O(N),所以在計(jì)算略大的數(shù)會(huì)花費(fèi)一定的時(shí)間和空間。遞歸程序如下:
#includeusing namespace std; unsigned long long Fib(size_t num) { if (num < 2) { return num; } else return Fib(num - 1) + Fib(num - 2); } int main() { unsigned long long ret = Fib(10); cout << ret << endl; system("pause"); return 0; }
用迭代方法計(jì)算第N 個(gè)斐波那契數(shù),時(shí)間復(fù)雜度O(N),空間復(fù)雜度O(1),程序如下:
#includeusing namespace std; unsigned long long Fib(size_t num) { unsigned long long first = 0; unsigned long long second = 1; unsigned long long sum = 0; if (num < 2) return num; else for (size_t i = 2; i <= num; i++) { sum = first + second; first = second; second = sum; } return sum; } int main() { unsigned long long ret = Fib(10); cout <<"Fibonacci(10)="<< ret << endl; system("pause"); return 0; }
創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務(wù)器,動(dòng)態(tài)BGP最優(yōu)骨干路由自動(dòng)選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動(dòng)現(xiàn)已開啟,新人活動(dòng)云服務(wù)器買多久送多久。