zoukankan      html  css  js  c++  java
  • 递归算法求阶乘(一)

    递归

      递归做为一种算法在程序设计语言中广泛应用.是指函数/过程/子程序在运行过程序中直接或间接调用自身而产生的重入现像.
      程序调用自身的编程技巧称为递归( recursion)。
    注意:
      (1) 递归就是在过程或函数里调用自身;
      (2) 在使用递归策略时,必须有一个明确的递归结束条件,称为递归出口。
    递归算法一般用于解决三类问题:
      (1)数据的定义是按递归定义的。(Fibonacci函数)
      (2)问题解法按递归算法实现。(回溯)
      (3)数据的结构形式是按递归定义的。(树的遍历,图的搜索)
    以下是我求的1到100以内所有数的阶乘的和:

           public int jiecheng(int n)//第n个数的阶乘
            {
                if (n == 1)
                    return 1;
                else if (n == 2)
                    return 2;
                else
                    return n * jiecheng(n - 1);

            }
            public int sumjiecheng(int n)//n个阶乘的和
            {
                if (n == 1)
                    return 1;
                else if (n == 2)
                    return 3;

                else
                    return jiecheng(n) + sumjiecheng(n - 1);
           }
    最后调用:sumjiecheng(100);(计算出1到100以内所有数的阶乘的和)
    我们可以调用:jiecheng(8),求的是8的阶乘。

  • 相关阅读:
    《白骨精学习法》 21世纪职场必备学习技巧
    英雄不问出处
    整理ArcSDE 安装过程出现问题以及解决方法系列
    ArcEngine9.1结合VS2005开发技巧2则
    推荐一界面控件DotNetBar(含附件)
    常用易忘记Oracle命令(待续)
    ArcSDE中间件技术的生命力(蔡晓兵)
    ArcSDE 的存储机制
    (收藏)ITPUB的ORACLE之常用FAQ V1.0
    ORA01691错误
  • 原文地址:https://www.cnblogs.com/paper/p/1533103.html
Copyright © 2011-2022 走看看