• 递归算法


    递归(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<<"盘子从"<<p1<<"移到"<<p3<<endl; else { hanoi(n-1,p1,p3,p2); cout<<"盘子从"<<p1<<"移到"<<p3<<endl; hanoi(n-1,p2,p1,p3); } }

    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); }

    荣耀存于心,而非留于形我还在寻找,回家的路长路漫漫,唯剑做伴且随疾风前行,身后一许流星吾虽浪迹天涯, 却未迷失本心
  • 相关阅读:
    build.gradle文件详解<转> 推荐
    openGL 环境配置
    手写 大整数
    FOJ有奖月赛-2016年8月(daxia专场之过四题方有奖)
    2.1 基本计数方法
    第7章 代码
    第7章 高级数据结构的编程实验
    3.3 字符串(1)
    2016_NENU_CS_3
    3.2 区间信息的维护与查询
  • 原文地址:https://www.cnblogs.com/qq3111901846/p/5909431.html
Copyright © 2020-2023  润新知