Skip to content

Commit

Permalink
feat: Add javascript and typescript code in chapter_computational_com… (
Browse files Browse the repository at this point in the history
#780)

* feat: Add javascript and typescript code in chapter_computational_complexity

* docs: Update code comment

* style: update code order th same with java
  • Loading branch information
wenjianmin committed Sep 24, 2023
1 parent 4b5e21d commit 26bf0c5
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 0 deletions.
23 changes: 23 additions & 0 deletions codes/javascript/chapter_computational_complexity/recursion.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,25 @@ function recur(n) {
return n + res;
}

/* 递归转化为迭代 */
function forLoopRecur(n) {
// 使用一个显式的栈来模拟系统调用栈
const stack = [];
let res = 0;
// 递:递归调用
for (let i = 1; i <= n; i++) {
// 通过“入栈操作”模拟“递”
stack.push(i);
}
// 归:返回结果
while (stack.length) {
// 通过“出栈操作”模拟“归”
res += stack.pop();
}
// res = 1+2+3+...+n
return res;
}

/* 尾递归 */
function tailRecur(n, res) {
// 终止条件
Expand All @@ -39,8 +58,12 @@ let res;
res = recur(n);
console.log(`递归函数的求和结果 res = ${res}`);

res = forLoopRecur(n);
console.log(`递归转化为迭代的求和结果 res = ${res}`);

res = tailRecur(n, 0);
console.log(`尾递归函数的求和结果 res = ${res}`);

res = fib(n);
console.log(`斐波那契数列的第 ${n} 项为 ${res}`);

22 changes: 22 additions & 0 deletions codes/typescript/chapter_computational_complexity/recursion.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,25 @@ function recur(n: number): number {
return n + res;
}

/* 递归转化为迭代 */
function forLoopRecur(n: number): number {
// 使用一个显式的栈来模拟系统调用栈
const stack: number[] = [];
let res: number = 0;
// 递:递归调用
for (let i = 1; i <= n; i++) {
// 通过“入栈操作”模拟“递”
stack.push(i);
}
// 归:返回结果
while (stack.length) {
// 通过“出栈操作”模拟“归”
res += stack.pop();
}
// res = 1+2+3+...+n
return res;
}

/* 尾递归 */
function tailRecur(n: number, res: number): number {
// 终止条件
Expand All @@ -39,6 +58,9 @@ let res: number;
res = recur(n);
console.log(`递归函数的求和结果 res = ${res}`);

res = forLoopRecur(n);
console.log(`递归转化为迭代的求和结果 res = ${res}`);

res = tailRecur(n, 0);
console.log(`尾递归函数的求和结果 res = ${res}`);

Expand Down

0 comments on commit 26bf0c5

Please sign in to comment.