1 구문을 사용합니다. ?n*fac(n-1):1}"."/> 1 구문을 사용합니다. ?n*fac(n-1):1}".">
방법: 1. for 루프 사용, 구문 "var cj=1;for(var i=1;i1?n*fac(n-1):1}".
이 튜토리얼의 운영 환경: Windows 7 시스템, JavaScript 버전 1.8.5, Dell G3 컴퓨터.
팩토리얼은 1808년 Christian Kramp(1760~1826)가 발명한 산술 기호입니다. 수학 용어입니다.
양의 정수의 팩토리얼은 해당 숫자보다 작거나 같은 모든 양의 정수의 곱이며, 0의 팩토리얼은 1입니다. 자연수 n의 계승은 n!으로 표시됩니다. 1808년에 Christian Carman이 이 표기법을 도입했습니다.
은 n!=1×2×3×...×(n-1)×n
。阶乘亦可以递归方式定义:0!=1
,n!=(n-1)!×n
을 의미하기도 합니다.
Javascript는 계승을 구현하는 여러 가지 방법을 지원합니다. 아래에서 살펴보겠습니다.
방법 1: for 루프를 사용하여 실현
13의 계승을 구하려면 1~13의 숫자를 순회해야 하므로 for 루프의 초기 조건을 i = 1로 설정할 수 있습니다. 제한 조건은 i
for (var i = 1; i <= 13; i++) { }
그런 다음 루프 본문 "{}"에서 각 루프의 i 값을 곱합니다. 결과에 영향을 미치지 않도록 변수 cj의 초기 값은 1이어야 합니다. 작성하는 방법은 두 가지가 있습니다(한 가지만 선택하세요):
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))
【추천 학습 : 자바스크립트 고급 튜토리얼】
위 내용은 자바스크립트에서 13의 계승값을 찾는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!