Your Ad Here
首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 网站建设 > PHP > javascript递归算法
【标  题】:javascript递归算法
【关键字】:javascript
【来  源】:http://blog.csdn.net/ITFLY8/archive/2006/08/31/1147338.aspx

javascript递归算法

Your Ad Here

递归是一种重要的编程技术。该方法用于让一个函数从其内部调用其自身。一个信手可得的示例就是计算阶乘。0 和 1 的阶乘都被特别地定义为 1。 更大数的阶乘是通过计算 1 * 2 * ...来求得的,每次增加 1,直至达到要计算其阶乘的那个数。


下面的段落是用文字定义的计算阶乘的一个函数。

“如果这个数小于零,则拒绝接收。如果不是一个整数,则将其向下舍入为相邻的整数。如果这个数为 0 或 1,则其阶乘为 1。如果这个数大于 1,则将其与相邻较小的数的阶乘相乘。”

要计算任何大于 1 的数的阶乘,至少需要计算一个其他数的阶乘。用来实现这个功能的函数就是已经位于其中的函数;该函数在执行当前的这个数之前,必须调用它本身来计算相邻的较小数的阶乘。这就是一个递归示例。

显然,这样有可能会出现问题。可以很容易地创建一个递归函数,但该函数不能得到一个确定的结果,并且不能达到一个终点。这样的递归将导致计算机执行一个“无限”循环。下面就是一个示例:在计算阶乘的文字描述中遗漏了第一条规则(对负数的处理) ,并试图计算任何负数的阶乘。这将导致失败,因为按顺序计算 -24 的阶乘时,首先不得不计算 -25 的阶乘;然而这样又不得不计算 -26 的阶乘;如此继续。很明显,这样永远也不会到达一个终止点。

因此在设计递归函数时应特别仔细。如果怀疑其中存在着无限递归的可能,则可以让该函数记录它调用自身的次数。如果该函数调用自身的次数太多,即使您已决定了它应调用多少次,就自动退出。

下面仍然是阶乘函数,这次是用 javascript 代码编写的。

function factorial(aNumber) {
aNumber = Math.floor(aNumber); // 如果这个数不是一个整数,则向下舍入。
if (aNumber < 0) { // 如果这个数小于 0,拒绝接收。
return "not a defined quantity";
}
if ((anumber == 0) || (anumber == 1)) { // 如果为 0 或 1,则其阶乘为 1。
return 1;
}
else return (anumber * factorial(anumber - 1)); // 否则,递归直至完成。

基于B/S 架构的应用软件的简单注册方法(VB.NET):【上一篇】
javascript常用函数:【下一篇】
【相关文章】
  • javascript 类的继承和实例化
  • Javascript的Event对象
  • 使用javascript+xml实现分页
  • 编写了一个支持firefox和ie的javascript+xml进行数据分页的程序
  • javascript + DIV +CSS 实现可拖动消息窗体
  • 使用Javascript读取Excel文件
  • javascript入门·脚本执行的时间的四种类型(赠送一个转换的小例题)
  • javascript入门·简单运算和数据类型转换
  • javascript入门系列演示·流程控制之 判断、循环
  • javascript入门系列演示·函数的定义以及简单参数使用,调用函数
  • 【随机文章】
  • 应用AutoCAD几何计算器实现快速定位
  • ontape dbexport注意的问题
  • OSPF问题集锦
  • TCP/IP远程访问操作:rlogin,rwho,rsh,rcp
  • GetQueuedCompletionStatus的返回值
  • TOP Global无线网卡
  • 操作系统常见问题:排除Rundll32错误(Mmsystem.dll)
  • 双面夏娃多如牛毛兔子毛,又安能尽得而诛
  • 基于J2EE的Web性能调优——基础知识篇(待续)
  • 双机家庭无线组网—双机组网指南
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 bbb软讯网络 All Rigths Reserved.