題目:
編寫一個函數,它返回兩個long變量中較小值的引用。編寫另一個函數,它返回較大值的引用。使用這兩個函數生成斐波納契級數的元素,即1,1,2,3,5,8,13……序列,其中每個數都等于前兩個數之和,元素的個數由用戶指定(提示:把序列中的兩個數字存儲在n1和n2中,它們都從1開始。如果把兩個數的和存儲在較小的變量中,并輸出較大的值,就會得到希望的結果。難點是為什么這是可行的)。
答案:
#include <iostream>
#include <iomanip>
using std::cout;
using std::cin;
using std::endl;
long& smaller(long& m, long& n);
long& larger(long& m, long& n);
void main() {
int count = 0;
cout << "How many values in the Fibonacci sequence would you like? ";
cin >> count;
long n1 = 1L; // First in sequence
long n2 = 1L; // Second in sequence
cout << endl
<< std::setw(15) << n1
<< std::setw(15) << n2;
for (int i=2; i<count; i++)
{
if (i%5 == 0)
cout << endl;
smaller(n1, n2) = n1 + n2;
cout << std::setw(15) << larger(n1, n2);
}
cout << endl;
}
long& smaller(long& m, long& n)
{
return m<n?m:n;
}
long& larger(long& m, long& n)
{
return m>n?m:n;
}