您好,登录后才能下订单哦!
这篇文章主要讲解了“javascript如何求13阶乘”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript如何求13阶乘”吧!
方法:1、利用for循环,语法“var cj=1;for(var i=1;i<=13;i++){cj *= i;}”;2、利用递归函数,语法“function fac(n){if(n <= 1){return 1;}else{return n*fac(--n);}}”;3、利用三元运算符,语法“function fac(n){return n>1?n*fac(n-1):1}”。
阶乘是基斯顿·卡曼(Christian Kramp,1760~1826)于 1808 年发明的运算符号,是数学术语。
一个正整数的阶乘(factorial)是所有小于及等于该数的正整数的积,并且0的阶乘为1。自然数n的阶乘写作n!。1808年,基斯顿·卡曼引进这个表示法。
亦即n!=1×2×3×...×(n-1)×n
。阶乘亦可以递归方式定义:0!=1
,n!=(n-1)!×n
。
javascript中支持多种方法来实现阶乘,下面一起来看看。
方法1:利用for循环来实现
想要求13的阶乘,就需要遍历1~13的数字,因此for循环的初始条件可设置为 i = 1,限制条件可以是 i <= 13 或者 i < 14。
然后在循环体“{}”中,将每次循环的i值相乘。这就需要一个中间量cj来存乘积,变量cj的初始值要为1,这样才不会影响结果。有两种写法(任选一个就行):for (var i = 1; i <= 13; i++) {
}
cj *= i;
//或
cj = cj * i;
等循环结束后,变量cj的值就13的阶乘,输出即可。
下面给出完整实现代码:
登录后复制var cj = 1;
for (var i = 1; i <= 13; i++) {
cj *= i;
}
console.log( "13的阶乘为: " + cj);
方法2:利用递归函数来实现
function fac(num) {
if (num <= 1) {
return 1;
} else {
// 闭包
return num * fac(--num); //方法一
//return num*fac(num-1); //方法二
// return num*arguments.callee(num-1);//方法三
// return num*arguments.callee(--num);//方法四
/*但在严格模式下不能通过脚本访问arguments.callee*/
}
}
var result = fac(13);
console.log( "13的阶乘为: " + result);
方法3:利用三元运算符
function fac(n) {
return n > 1 ? n * fac(n - 1) : 1
}
console.log('2的阶乘为:', fac(2))
console.log('3的阶乘为:', fac(3))
console.log('4的阶乘为:', fac(4))
console.log('13的阶乘为:', fac(13))
感谢各位的阅读,以上就是“javascript如何求13阶乘”的内容了,经过本文的学习后,相信大家对javascript如何求13阶乘这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。