博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
逻辑分析题汇总(一)
阅读量:5013 次
发布时间:2019-06-12

本文共 1499 字,大约阅读时间需要 4 分钟。

1.有一对兔子,从出生后第 3 个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 

 程序分析: 兔子的规律为数列: 1 1,2,3,5,8,13,21,34,表示了一种动植物数量的正常增长的数量变化

                                  月份: 1  2 3 4 5 6  7  8 9 10

第一种方法:使用递归——但这种方法递归调用的效率非常低。

1 function dd(n){2         if (n < 3) {return 1;}3         if(n >= 3){//这里注意n还有等于3的情况,不然会导致递归中断4             return (dd(n-1)+dd(n-2));5         }6     }7    console.log(dd(10));

第二种方法:使用循环

// f(n-2)+f(n-1) = f(n)         //   1      1       2   n=3         //   1      2       3   n=4         //   2      3       5   n=5         //   3      5       8   n=6    function dd(n){        var a =1,b=1,c=1;        for(var i =3;i <= n;i++){            a =b;            b =c;            c= a+b;        }        return c;    }   console.log(dd(6));

  

这种方式更加巧妙。

2.将一个正整数分解质因数。例如:输入 90, 打印出 90=2*3*3*5 。

function fenjie(n){         var arr=[];         for(var i =2;i < n/2;i++){             while(n % i == 0){while循环在指定条件为true时,就一直执行;不满足的话,就跳出循环                 arr.push(i);                 n/=i;//此处不断的循环             }         }         return arr.join('*');     }     console.log('90 = ' + fenjie(90));

  

3.要求输出国际象棋棋盘。

在这里使用嵌套循环。

//外层循环控制行         for(var i = 0,str ='';i<8;i++){            //内层循环控制列            for(var j = 0;j< 8;j++){                //拼接一个正方形:如果r+c为偶数;就拼接空心方块,否则拼接实心方;                str += (i+j)%2 ==0?'□':'■';            }            str+='\n';        }        console.log(str);

  实现效果:

在这里我们比较了几种情况,需要分析下:

输出情况:会输出每一次循环的值:

修改代码后:

输出

修改代码:

输出

修改代码:

输出

 

转载于:https://www.cnblogs.com/ydaimee/p/6749932.html

你可能感兴趣的文章
Git常用命令总结
查看>>
iOS获取设备IP地址
查看>>
JavaSE| String常用方法
查看>>
NRF51822配对绑定要点
查看>>
C语言博客作业—数据类型
查看>>
[leetcode]Count and Say
查看>>
cookie、session和token的概念入门
查看>>
保护网站页面内容+版权
查看>>
Golang模拟客户端POST表单功能文件上传
查看>>
重启进程
查看>>
js 进度条效果
查看>>
RelativeLayout
查看>>
注意细节
查看>>
currying 柯里化,返回函数
查看>>
ASP.NET WebForm(MVC)下实现消息推送(提供简单Demo下载)
查看>>
Java IO流
查看>>
python调用C语言
查看>>
第一阶段意见评论
查看>>
【EF6学习笔记】(七)读取关联数据
查看>>
2015 省赛随便写写
查看>>