递归(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;
}