大家好!我是不爱唱歌的小夏,一个前端爱好者,希望与大家共同进步。
下面分享几个问题:
问题1:你有20元,每瓶可乐3元,一个空瓶1元,最后买几瓶可乐?
首先我们先分析此题的数据结构: 1)有20元:mon=20; 2)每瓶可乐3元:eachCola=3; 3)一个空瓶1元:emptyBottle=0; 4)最后买几瓶可乐:count=0; 算法分析:
首先20元能买:count = mon/eachCola;//注意这里的count要转化成整数! 那么空瓶子共有:emptyBottle = count; 剩余:mon = mon - (3-1)*emptyBottle;分析得每次购买其实是一次相同的循环,那么我们可以简单的写一个循环来解决此问题; 循环的条件就是mon>eachCola; 源码如下:
var mon = 24, eachCola = 3, emptyBottle = 0, count = 0; while (mon > eachCola) { emptyBottle = parseInt(mon / eachCola); mon = mon - 2 * emptyBottle; count = emptyBottle + count; } console.log(count);问题2:输出1-100之间所有的质数
算法分析:质数=除了1和自身没有其他因数; 代码如下:
for (var i = 2; i <= 100; i++) { var flag = true;//质数开关 var count = 0; for (var j = 2; j < i; j++) {//判断是否质数 if (i % j == 0) { flag = false;//非质数将开关关上(false) } } if (flag) {//输出质数 console.log(i); } }问题3:打印如下图形 数据分析: 第一行 一个数字 “1”; 第二行三个数字“121” 第三行四个数字“1331” 到此我们其实已经可以找到简单的规律: 即: 第1行输出1; 第二行第一个数输出1,中间输出2-1个2,最后一个数输出1; 第三行第一个数输出1,中间输出3-1个3,最后一个数输出1; … … 代码如下:
for (var i = 1; i <= 6; i++) { if (i == 1) { document.write(`${i}</br>`); } else { document.write(1); for (var j = 1; j < i; j++) { document.write(i); } document.write(1 + `</br>`); } }@author by im_xiaoxia 我是不爱唱歌的小夏,下次见!