JavaScript使用递归和循环实现阶乘的实例代码
2018-08-28 10:23
1031 查看
【实现方法】
1.利用while循环来做,当然for循环也可以。
2.递归
【代码内容】
偷懒,直接用onkeyup事件来限制来页面的输入
循环代码:
//第一种方法 while循环 oCount.onclick = function (){ var oNum = document.getElementById('num').value; oNum = Number(oNum); if(oNum <= 1){ oBox.innerHTML = 1; } var oRes = 1; while(oNum){ oRes *= oNum; oNum--; } oBox.innerHTML = oRes; }
递归代码
// 第二种方法 递归 oCount.onclick = function(){ var oNum = document.getElementById('num').value; oNum = Number(oNum); function factorial (num) { if (num <= 1) { return 1; } else { return (num * factorial(num-1)); } }; oRes=factorial(oNum); oBox.innerHTML = oRes; };
完整代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>两种实现阶乘方法</title> <style> #box { width: 100%; height: 200px; border: 1px solid #ccc; text-align: center; } </style> <script> window.onload = function() { var oBox = document.getElementById('box'); var oCount = document.getElementById('count'); // 第一种方法 while循环 // oCount.onclick = function (){ // var oNum = document.getElementById('num').value; // oNum = Number(oNum); // if(oNum <= 1){ // oBox.innerHTML = 1; // } // var oRes = 1; // while(oNum){ // oRes *= oNum; // oNum--; // } // oBox.innerHTML = oRes; // } // 第二种方法 oCount.onclick = function(){ var oNum = document.getElementById('num').value; oNum = Number(oNum); function factorial (num) { if (num <= 1) { return 1; } else { return (num * factorial(num-1)); } }; oRes=factorial(oNum); oBox.innerHTML = oRes; }; } </script> </head> <body> <div id="box"></div> <input type="text" id="num" onkeyup="value=value.replace(/[^0-9]/g,'')" onpaste="value=value.replace(/[^0-9]/g,'')" oncontextmenu = "value=value.replace(/[^0-9]/g,'')"> <input type="button" id="count" value="计算"> </body> </html>
下面通过代码看下javascript 中阶乘函数方法
好久没有弄了,练习下:
// 第一, 向上加的阶层函数计算方法 var number = function(n) { if(n == 1) { return 1 } else { product = 1; for(i = 1; i <= n; i++) { product *= i; } return product; } } var d = number(5); alert(d); // 第二, 往下减的阶层函数 var del = function(n) { if(n == 1) { return 1 } else { return n * del(n - 1); } } var data= del(5); alert(data);
总结
以上所述是小编给大家介绍的JavaScript使用递归和循环实现阶乘的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章:
相关文章推荐
- Javascript 实现匿名递归的实例代码
- 使用JavaScript实现alert的实例代码
- 使用JavaScript实现ajax的实例代码
- 使用JavaScript实现ajax的实例代码
- submit应用实例全面实现一段代码多次使用(ALV显示然后打印)
- javascript实现上传图片并预览的效果代码实例
- 使用JavaScript代码实现各种数据控件的反选功能 不要只做拖控件的菜鸟
- JavaScript中使用构造函数实现继承的代码
- javascript中利用数组实现的循环队列代码
- Javascript 键盘事件的组合使用实现代码
- 在ASP.NET使用JavaScript显示信息提示窗口实现原理及代码
- 使用递归实现阶乘
- 在ASP.NET使用JavaScript显示信息提示窗口实现原理及代码
- js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码)
- 使用JavaScript代码实现各种数据控件的反选功能,不要只做拖控件的菜鸟
- javascript实现cookies的查询代码实例
- javascript cookie操作类的实现代码小结附使用方法
- PHP foreach循环使用详解与实例代码
- 利用javascript实现遍历xml文件的代码实例
- C#使用Mutex实现系统范围内单实例运行的示例代码