您的位置:首页 > 编程语言

使用模板元编程快速的得到斐波那契数。。

2012-04-02 12:32 162 查看
这是一种将运行时消耗转移到编译器消耗的方法,是c++模板的一种应用。

当你的程序运行时效率需要特别高的时候,可以考虑这样的方法。

模板实例化的时候需要常量:

#include <iostream>
using namespace std;
template < unsigned N >
struct Fib
{
enum
{
Val = Fib<N-1>::Val + Fib<N-2>::Val //递归。。
};
};
template<>    //针对和的特化作为结束的条件
struct Fib<0>
{
enum
{
Val = 0
};
};
template<>
struct Fib<1>
{
enum
{
Val = 1
};
};
int main()
{
cout<<Fib<20>::Val <<endl;
return 0;
}


如果你觉得Fib<20>::Val这样的调用很麻烦的话可以定义一个类似的宏使得其应用有类似于函数调用的形式:

#define FibFuc( n ) (Fib<n>::Val)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: