C++求Fib數(shù)列
1. 第一版本程序
int fib(int pos)
{
int elem = 1;
int n1 = 1, n2 = 1;
for (int i = 3; i <= pos; i++)
{
elem = n2 + n1;
n1 = n2;
n2 = elem;
}
return elem;
}
2. 第二版本
bool fib(int pos, int &elem)
{
if(pos < 0 || pos > 1024)
{
elem = 0;
return false;
}
elem = 1; //注意:定義只能有1次
int n1 = 1, n2 = 1;
for (int i = 3; i <= pos; i++)
{
elem = n2 + n1;
n1 = n2;
n2 = elem;
}
return true;
}
主函數(shù)調(diào)用
int main()
{
int pos;
cout <<"Please enter a position: ";
cin >> pos;
int elem;
if(fib(pos, elem))
{
cout << "element # " << pos
<< " is " << elem << endl;
}
else
cout << "Sorry. Couldn't calculate element #"
<< pos <<endl;
}
3. 第三版本 改進(jìn)后的fib
const vector<int>* fib_new(int size)
{
const int max_size = 1024;
static vector<int> elems;
if(size <= 0 || size >= max_size)
{
cerr << "fib_new(): oops:invalid size:"
<< size << "-- can't fulfill request.\n";
return 0;
}
for(int ix = elems.size(); ix < size; ix++)
{
if (ix == 0 || ix == 1)
elems.push_back(1);
else
elems.push_back(elems[ix - 1] + elems[ix - 2]);
}
return &elems;
}
主函數(shù)調(diào)用
const vector<int> *result=fib_new(5);
cout << result->back();
const vector<int> *result=fib_new(5);
cout << result->at(4)<< endl;
//這個應(yīng)該怎么多次調(diào)用返回,這個還沒明白,留個記號。
最后這個版本可以避免進(jìn)行重復(fù)運(yùn)算,使用了局部靜態(tài)對象。
上一篇:C語言完美實現(xiàn)動態(tài)數(shù)組代碼分享
欄 目:C語言
下一篇:C/C++仿華容道小游戲
本文標(biāo)題:C++求Fib數(shù)列
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/2489.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段函數(shù)
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求階乘
- 01-10c語言求1+2+...+n的解決方法
- 01-10求子數(shù)組最大和的解決方法詳解
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-用棧實現(xiàn)表達(dá)式求值的方法詳解
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10用貪心法求解背包問題的解決方法
- 01-10求斐波那契(Fibonacci)數(shù)列通項的七種實現(xiàn)方法
- 01-10使用C++實現(xiàn)全排列算法的方法詳解


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-10C#中split用法實例總結(jié)
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10delphi制作wav文件的方法


