亲宝软件园·资讯

展开

C++函数对象

清风自在 流水潺潺 人气:0

一、客户需求

编写一个函数

  1. 函数可以获得斐波那契数列每项的值
  2. 每调用一次返回一个值
  3. 函数可根据需要重复使用

下面来看第一个解决方案:

#include <iostream>
using namespace std;
int fib()
{
    static int a0 = 0;
    static int a1 = 1;
    int ret = a1;
    a1 = a0 + a1;
    a0 = ret;
    return ret;
}
int main()
{
    for (int i = 0; i < 10; i++)
    {
        cout << fib() << endl;
    }
    cout << endl;
    for (int i = 0; i < 5; i++)
    {
        cout << fib() << endl;
    }
    return 0;
}

输出结果如下:

二、存在的问题

函数一旦开始调用就无法重来

三、解决方案

函数对象

四、函数对象

函数调用操作符(( ))

所以最终解决方案如下:

#include <iostream>
using namespace std;
class Fib
{
    int a0;
    int a1;
public:
    Fib()
    {
        a0 = 0;
        a1 = 1;
    }
    Fib(int n)
    {
        a0 = 0;
        a1 = 1;
        for (int i = 2; i <= n; i++)
        {
            int t = a1;
            a1 = a0 + a1;
            a0 = t;
        }
    }
    int operator () ()
    {
        int ret = a1;
        a1 = a0 + a1;
        a0 = ret;
        return ret;
    }
};
int main()
{
    Fib fib;
    for (int i = 0; i < 10; i++)
    {
        cout << fib() << endl;
    }
    for (int i = 0; i < 5; i++)
    {
        cout << fib() <<endl;
    }
    cout << endl;
    Fib fib2(10);
    for (int i = 0; i < 5; i++)
    {
        cout << fib2() << endl;
    }
    return 0;
}

输出结果如下:

五、小结

加载全部内容

相关教程
猜你喜欢
用户评论