关于“递归”的探讨

13 篇文章 0 订阅

递归(recursion):程序调用自身的编程技巧。递归满足2个条件:
(1)有反复执行的过程(调用自身)
(2)有跳出反复执行过程的条件(递归出口)

以下是一些常见的例子

  1、快速判断一个整数是否是2的整数幂次方,并判断出来是多少次方

  算法设计:整数的移位和除以2在效果上相同。例如8/2=4,8>>1 = 4;3不是整数次幂,返回-1

//命名为mylog2,math.h头文件中包含log2这个函数
#include <stdio.h>
int mylog2(int value)
{
   if((value & 0x01) == 1)//当不是整数次幂的时候直接退出
	   return -1;
   return (value == 1) ? 0:(1+mylog2(value>>1));
}
int main(void)
{
    printf("%d\n",mylog2(3));
    printf("%d\n",mylog2(256));
    return 0;
}
2、有1米和2米规格的两种铁轨,问铺设n米长的轨道有多少种组合方式。
例如铺设4米的轨道,组合方法有:1 1 1 1,1 1 2 ,1 2 1,2 1 1 四种。

算法设计:步骤:想要铺设n米长铁轨,先铺设规格1米,后面的有fun1(n-1)中方法;先铺设2米,则有fun1(n-2)中方法。所以总的方法是fun1(n-1)+fun1(n-2)

#include <stdio.h>
int fun1(int n)
{
   return (n <= 2)?n:fun1(n-1) + fun1(n-2);
}
int main(void)
{
   printf("%d\n",fun1(0));
   printf("%d\n",fun1(1));
   printf("%d\n",fun1(2));
   printf("%d\n",fun1(3));
   printf("%d\n",fun1(4));
   printf("%d\n",fun1(5));
   printf("%d\n",fun1(6));
   printf("%d\n",fun1(7));
   printf("%d\n",fun1(8));
   printf("%d\n",fun1(9));
   printf("%d\n",fun1(45));
   printf("%d\n",fun1(46));//组合数超出了返回值的范围,溢出
   return 0;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值