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的阶乘。

  • 相关阅读:
    OpenJudge 2764 数根 C++
    OpenJudge / Poj 1835 宇航员 C++
    elasticsearch系统性能调优总结
    ES基本查询总结
    Vim最全快捷键键位图
    Idea常用插件整合
    微信小程序开发资源汇总
    Java JNI调用本地动态库使用详解
    java开发调试定位分析工具大全
    Redux-saga使用教程详解
  • 原文地址:https://www.cnblogs.com/paper/p/1533103.html
Copyright © 2011-2022 走看看