登录  /  注册
博主信息
博文 128
粉丝 9
评论 5
访问量 233685
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
【递归】JavaScript实现99乘法表的编写(双层for循环与递归方法)
 一纸荒凉* Armani
原创
1318人浏览过

JavaScript中递归

递归函数:递归函数是在通过名字调用自身的情况下构成的

这句话理解起来并不难,从概念上出发,给出以下的例子:

  1. function foo(){
  2. console.log("函数 foo 是递归函数。");
  3. foo();
  4. }

这个例子的 foo 函数就是一个递归函数。

当你把这个函数拿到浏览器上运行的时候,你会发现内存溢出了,为什么呢?因为这个递归函数没有停止处理或运算的出口,因此
这个递归函数就演变为一个死循环。

递归函数的作用和循环的效果一样
递归很容易发生“栈溢出”Stack overflow 错误,所以必须要添加退出条件

  1. var num = 1;
  2. function fn(){
  3. console.log('打印hello');
  4. if(num == 6){
  5. return;
  6. }
  7. num++;
  8. fn();
  9. }
  10. fn();

利用递归函数求1-n的阶乘12345…….n

  1. function fn(n){
  2. if(n== 1) {
  3. return 1;
  4. }
  5. return n * fn(n-1);
  6. }
  7. fn();
  8. //思路:假如用户输入3
  9. //return 3 * fn(2)
  10. //return 3 * fn(2 * fn(1))
  11. //return 3 * fn(2 * 1)
  12. //return 3 * 2
  13. //return 6

使用建议:在使用递归时,要注意对递归函数的参数类型的检查,一定要保证有一个终止处理或计算的出口。否则很容易演变为死循环,从而造成内存溢出。

九九乘法表

双层for循环实现方法:

  1. function nine (num) {
  2. for(var i = 1; i <= num; i++){
  3. var str = '';
  4. for(var k = 1; k <= num; k++){
  5. if(i >= k){
  6. str += k + 'x' + i + '=' + i*k + ' ';
  7. }
  8. }
  9. console.log(str)
  10. }
  11. }
  12. nine(9)

递归实现方法:

  1. function nine (num) {
  2. if(num == 1) {
  3. console.log('1x1=1')
  4. } else {
  5. nine(num - 1);
  6. for(var i = 1, str = ''; i <= num; i++){
  7. str += i + 'x' + num + '=' + i*num + ' '
  8. }
  9. console.log(str)
  10. }
  11. }
  12. nine(9)

只需要改下递归方法的位置,如下:

  1. function nine (num) {
  2. if(num == 1) {
  3. console.log('1x1=1')
  4. } else {
  5. for(var i = 1, str = ''; i <= num; i++){
  6. str += i + 'x' + num + '=' + i*num + ' '
  7. }
  8. console.log(str)
  9. nine(num - 1); // 更换下递归方法的位置
  10. }
  11. }
  12. nine(9)


每一次的记录,都是向前迈进的一步

本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学