递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
来源:互联网 发布:国外大学网络课程 编辑:程序博客网 时间:2024/06/10 22:45
By Ben
比如求 10! 的结果
比如求 10! 的结果
有两种解法:
法一:
一般的做法:
//===========================
document.writeln("<br/>递归算法一:<br/>");
//===========================
function factorial(x) {
if(x < 2)
return 1;
else
return x * factorial(x - 1);
}
document.writeln("10!=" + factorial(10));
document.writeln("<br/>递归算法一:<br/>");
//===========================
function factorial(x) {
if(x < 2)
return 1;
else
return x * factorial(x - 1);
}
document.writeln("10!=" + factorial(10));
法二:
还可在类的方法中执行递归,但这有点儿冒险。
在JavaScript中调用类的方法名来进行递归,会造成“Object Expected”错误。为避免这个错误,必须用方法的基本函数名或callee参数来执行递归。以清单D为基础,我在myMath类中添加了阶乘方法,如下所示。
在JavaScript中调用类的方法名来进行递归,会造成“Object Expected”错误。为避免这个错误,必须用方法的基本函数名或callee参数来执行递归。以清单D为基础,我在myMath类中添加了阶乘方法,如下所示。
document.writeln("<br/>递归算法二:<br/>");
function myMath() {
//=======================================
this.result; //Result of method
this.factorial = myFactorial; //Factorial method
this.result; //Result of method
this.factorial = myFactorial; //Factorial method
function myFactorial(x) {
if(x < 2)
return 1;
else {
this.result = x * arguments.callee(x - 1);
if(x < 2)
return 1;
else {
this.result = x * arguments.callee(x - 1);
return this.result;
}
}
}
}
//=======================================
}
}
var math = new myMath(); // Create an instance
document.writeln("10! =" + math.factorial(10));
document.writeln("10! =" + math.factorial(10));
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- 给文本框初始化值
- 金牛座的我,金牛座的错(已更新)
- Windows下的JAVA环境配置
- 怎么还就有人不相信mfc过时了?
- 设计模式-创建型模式
- 递归算法在javascript中使用的小技巧 (javascript的对象封装方法介绍)
- “工作流”关键字在Google上的赞助商
- RedHat Linux 9 下远程桌面的安装与配置
- 工作流专题的调研(一)[摘要]
- 动态创建Tree
- 领域驱动的开发
- .NET 的 Lucene
- 在Tomcat下JSP、Servlet,JavaBean和Struts环境的配置
- pageContext的认识