博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
递归算法
阅读量:6714 次
发布时间:2019-06-25

本文共 1038 字,大约阅读时间需要 3 分钟。

递归(recursion):程序调用自身的编程技巧。

  递归满足2个条件:

    1)有反复执行的过程(调用自身)

    2)有跳出反复执行过程的条件(递归出口)

 

递归例子:

(1)阶乘

         n! = n * (n-1) * (n-2) * ...* 1(n>0)

//阶乘 int recursive(int i) { int sum = 0; if (0 == i) return (1); else sum = i * recursive(i-1); return sum; }

(2)河内塔问题

//河内塔 void hanoi(int n,int p1,int p2,int p3) { if(1==n) cout<<"盘子从"<
<<"移到"<
<

3)全排列

  从n个不同元素中任取m(m≤n)个元素,按照一定的顺序排列起来,叫做从n个不同元素中取出m个元素的一个排列。当m=n时所有的排列情况叫全排列。

  如1,2,3三个元素的全排列为:

  1,2,3

  1,3,2

  2,1,3

  2,3,1

  3,1,2

  3,2,1 

//全排列 inline void Swap(int &a,int &b) { int temp=a; a=b; b=temp; } void Perm(int list[],int k,int m) { if (k == m-1) { for(int i=0;i

(4)斐波那契数列

  斐波纳契数列,又称黄金分割数列,指的是这样一个数列:1、1、2、3、5、8、13、21、……

  这个数列从第三项开始,每一项都等于前两项之和。

  有趣的兔子问题:

 

  一般而言,兔子在出生两个月后,就有繁殖能力,一对兔子每个月能生出一对小兔子来。如果所有兔子都不死,那么一年以后可以繁殖多少对兔子?

  分析如下:

  第一个月小兔子没有繁殖能力,所以还是一对;

  两个月后,生下一对小兔子,总数共有两对;

  三个月以后,老兔子又生下一对,因为小兔子还没有繁殖能力,总数共是三对;

  …… 

  依次类推可以列出下表:

//斐波那契 long Fib(int n) {  if (n == 0)    return 0;  if (n == 1)    return 1;  if (n > 1)    return Fib(n-1) + Fib(n-2); }

转载于:https://www.cnblogs.com/qq3111901846/p/5909431.html

你可能感兴趣的文章
IntelliJ IDEA 2017.3.1 使用手册
查看>>
互联网协议入门(2)
查看>>
泛型的通配符问题
查看>>
DataSource的可配参数有哪些,有哪些DataSource可以用
查看>>
简介数据仓库
查看>>
免费的后台管理界面框架
查看>>
本地文件共享服务(nfs samba ftp)
查看>>
scp通过代理proxy传输文件
查看>>
excel 打开时报“发现不可读的内容...”
查看>>
pandas-利用python进行数据分析
查看>>
数据段、代码段、堆栈段、BSS段的区别
查看>>
Apache Bench
查看>>
WebService之Axis2快速入门(5): 管理会话(Session)
查看>>
以太坊RPC接口使用
查看>>
小管家,一款个人记帐工具^_^
查看>>
轻应用高并发构建方案
查看>>
普通html标签<form>和struts2<s:form>的区别
查看>>
安装NTFS For Mac时显示文件已损坏怎么办
查看>>
-webkit-line-clamp实现多行文字溢出隐藏显示省略号
查看>>
Sublime Text 3 - 设置自动换行
查看>>