开发者社区> 问答> 正文

递归算法流程图如何画请以菲波那切数列递归算法为例

int fibo2(int n) { if(n==0||n==1 ) return (1); else return(fibo2(n-1)+fibo2(n-2)); }

展开
收起
知与谁同 2018-07-19 09:40:00 2729 0
1 条回答
写回答
取消 提交回答
  • 阿里云开发者社区运营负责人。原云栖社区负责人。
    递归(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<m;i++)
    {
    printf("%d",list[i]);
    }
    printf("n");
    }
    else
    {
    for(int i=k;i<m;i++)
    {
    Swap(list[k],list[i]);
    Perm(list,k+1,m);
    Swap(list[k],list[i]);
    }
    }
    }
    2019-07-17 22:54:36
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
数据+算法定义新世界 立即下载
袋鼠云基于实时计算的反黄牛算法 立即下载
Alink:基于Apache Flink的算法平台 立即下载