C++拾遗--模板元编程
前言
模板元是用于递归加速的,把运行期的函数调用变到编译期进行代码展开,类似于内联函数。下面看一个实例:斐波那契数列第n项求解。
模板元编程
#include <iostream>
#include <ctime>
using namespace std;
//递归法
int fib(int n)
{
if (n < 0)
return 0;
if (n == 1 || n == 2)
return 1;
return fib(n - 1) + fib(n - 2);
}
//模板元
template<int N>
struct Data
{
enum{ res = Data<N-1>::res + Data<N-2>::res };
};
template<>
struct Data<1>
{
enum{ res = 1 };
};
template<>
struct Data<2>
{
enum{ res = 1 };
};
int main()
{
cout << "******模板元编程***by David***" << endl;
time_t start, end;
s