斐波那契数列打印机

template<int v>
struct fnum
{
        enum { val = fnum<v-2>::val + fnum<v-1>::val };
};

template<>
struct fnum<0>
{
        enum { val = 1 };
};
template<>
struct fnum<-1>
{
        enum { val = 1 };
};

template<int count>
struct fnumber_printer
{
     static int print()
     {
         printf("%d", fnumber_printer<count - 1>::print());
  
         return fnum<count>::val;
     }
};
template<>
struct fnumber_printer<1>
{
     static int print()
     {
          return fnum<1>::val;
     }
};

收藏一下自己回帖写的代码,:)

特点:使用C++ meta programming方法。

无运行期迭代,无运行期循环,无临时变量。

也没有引入通项公式和产生是函数。

 缺点:函数调用次数成线性增长。

 可以改进的地方:在编译期确定全局静态整型数组尺寸,将数列写入该数组。

问题:全局只能生成一次数列,否则会出现编译错误。 一次生成,应该就够了。呵呵。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值