题目:
编写一个函数,它返回两个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;
}