JavaScript之递归和回调函数的应用

简单学习了JS中的递归和回调函数后,用相关的方法解决一些曾经文章解决过的小问题,如下:

例一:用递归求1+100的和,代码实现如下:

<script>
alert(getSum(100));
function getSum(n){
   //跳出条件
       if(n<1){
           return 0;
       }
       //累加
       return n+getSum(n-1);
   }
</script>
通过多次调用本身函数进行累加加和,这个过程叫做递归,给出条件使之跳出递归。

例二:用递归求斐波那契数列第12项?代码实现如下:

<script>
   console.log(FB(12));
   function FB(n) {
       if(n<=2){
           return 1;
       }
       return   FB(n-2)+FB(n-1);
   }
</script>

将以上代码进行优化,利用三目运算将代码量减少,如下:

<script>
function fib(n){
   return n <=2 ? 1: fib(n - 1) + fib(n - 2);
}
console.log(fib(12));
</script>
例三:定义四个规则,加减乘除,代码实现如下:

<script>
console.log(fn(10,5,test1));
   console.log(fn(10,5,test2));
   console.log(fn(10,5,test3));
   console.log(fn(10,5,test4));
   function fn(num1,num2,demo){
       return demo(num1,num2);
   }
   function test1(a,b){
       return a+b;
   }
   function test2(a,b){
       return a-b;
       }
   function test3(a,b){
       return a*b;
   }
   function test4(a,b){
       return a/b;
   }
</script>
先调用fn函数后再调用demo函数,完成回调规则。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值