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

简介:

这是一种将运行时消耗转移到编译器消耗的方法,是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)

目录
相关文章
|
6月前
|
C语言
C语言之使用递归的方法求n的阶乘
C语言之使用递归的方法求n的阶乘
150 0
|
4月前
|
算法 测试技术 C#
C++二分查找算法:阶乘函数后 K 个零
C++二分查找算法:阶乘函数后 K 个零
|
7月前
|
C语言
C语言中n的阶乘的两种思路
C语言中n的阶乘的两种思路
|
8月前
|
C语言
C语言练习---【求素数】(一篇带你掌握素数求解)
C语言练习---【求素数】(一篇带你掌握素数求解)
90 0
C语言练习---【求素数】(一篇带你掌握素数求解)
|
9月前
|
C语言
C语言使用递归方法求阶乘n!
C语言使用递归方法求阶乘n!
61 0
|
10月前
|
存储 算法 C语言
【数据结构实验】C语言-一元二项式操作
【数据结构实验】C语言-一元二项式操作
99 0
|
11月前
|
算法 程序员 C语言
C语言基础(有关三个数比较大小、冒泡排序、最大公约数、和有关某个数x的绝对值的n次方除于n的阶乘问题的函数求解法;和阶乘函数递归方法;和数组作函数参数的
C语言基础(有关三个数比较大小、冒泡排序、最大公约数、和有关某个数x的绝对值的n次方除于n的阶乘问题的函数求解法;和阶乘函数递归方法;和数组作函数参数的
|
11月前
|
BI C语言
c语言中,利用for循环来解决,求n的阶乘问题(简化版 - - )
c语言中,利用for循环来解决,求n的阶乘问题(简化版 - - )
|
11月前
|
C语言
【C语言】求第n个斐波那契数
斐波那契数:前两个数为1,后面的数为它前两个数之和
|
C语言
C语言计算n的阶乘
C语言计算n的阶乘
62 0
C语言计算n的阶乘