JS学习中遇到的一些题目
1.找出所有的水仙花数:
水仙花数例如:153 的特点:
1^3+5^3+3^=153 而且水仙花数只会是三位数,所以可以利用循环的方式来解决问题,循环条件可以设为:
var i = 1;i <=999; i++;因此具体过程如下:
var a, b, c; 作用:接受水仙花数的百,十,个位数
for (var i = 100;i <=999; i++){
a = parseInt(i / 100); i百位上的数
b = parseInt(((i / 10) % 10)); i十位上的数
c = i % 10; i个位上的数
if (i == a * a * a + b * b * b + c * c * c) 水仙花数的判断条件
{
document.write('水仙花数: ' + i + '<br/>'); 如果是水仙花数,将其打印出来。
}
};
2.斐波那契数列:
特点 1 1 2 3 5 8 13…… 即从第三个数开始每个数是前两个数的和所以具体做法如下:
var a = 1;
var b = 1;
var c;
var i=3;
document.write(a + "<br/>"); 打印不参与循环的第一个数
document.write(b + "<br/>"); 打印不参与循环的第二个数
while (i<=20) {
c = a + b; i=1时c=3,此时应如下两部将
a = b; 第一个数获得第二个数的值,
b = c; 第二个数获得第三个数的值,此时第四个数仍等于a+b,
i++;
document.write(c + "<br/>"); 打印从第三位开始的数
}
同类型的题还有兔子对数问题和1/2 2/3 3/5....的问题。
3.图形题:
[做图形题的思路]
1.确定图形一共有几行,即为外层循环的次数。
2.每行有几种元素,代表有几个内层循环。
3.确定每种元素的个数,即为每个内层循环的次数。
tips:通常找出每种元素个数与行号的关系式,即为当前内层循环的最大值;(从1开始。)
平行四边形
for(var i=1;i<=5;i++){ 共5行,每行有空格,星号两种元素,因此i<=5,里面有2个for循环
for(var j=1;j<i;j++){ 用于输出空格的循环,每行的个数等于行数减1,因此循环条件就j<i,循环次数即空格个数
document.write(" ");
}
for(var k=1;k<=5;k++){ 用于输出星号的循环,每行的个数等于5,因此循环条件就k<=5,循环次数即星号个数
document.write("*");
}
document.write("<br/>");
}
document.write("<br/>");

同时还有菱形等图形。
4.循环综合练习:atm取款
需求描述:假设一个简单的ATM机的取款过程为:
① 首先提示用户输入密码(password),假设默认密码为111111,最多只能输入3次,
② 超过3次则提示用户“密码错误,请取卡”,结束交易。
如果用户密码正确,再提示用户选择金额(amount),
“请输入0到6中任意数字选择对应钱数:0:手动输入金额,1:100元, 2:300元,3:500元, 4:1000元, 5:3000元, 6:5000元”。
输入数字如果错误,提示“输入错误,是否继续 Y/N”,选择Y重新提示输入钱数编号,
选择N提示“输入错误,请取卡!”。选择数字为1到6,打印对应钱数,
并提示“是否继续 Y/N”。选择数字0,ATM机只能输出100元纸币,
自定义钱数要求最低为100元,最高为1000元。如果用户输入的金额符合上述要求,
则打印输出用户取的钱数,并提示“取款完成,是否继续Y/N”;否则输出一句话“金额错误,
是否继续 Y/N”,如果用户输入Y,提示用户重新选择取款金额,如果用户输入 N,
打印“交易取消,请取卡!”
ps:取款成功后,应该提示用户是否继续,总取款金额不能超过2万
【解题思路】
1、验证密码
① 密码正确,继续执行下面操作;
② 密码错误3次,return;
2、取款操作。全部包含在 while循环内部。
① 提示选择编号;
② 根据编号,给money赋值。用switch结构实现。
1~6:直接给money赋固定值,0:手动赋值操作;
③ 验证取款是否成功。money-本次取款金额,moneySum-本次取款之前的总金额
判断moneySum+money是否>20000,3种情况:
>2000 本次取款超额,但moneySum之前并不足20000,继续下次循环;
=2000 取完本次money后,刚好满额。money可以加到sum上,然后return;
<2000 取完本次money后,仍未上限。money可以加到sum上,继续下次循环。
④ 验证是否继续,while-if结构实现,有3种情况:
Y/y 将小循环break,继续执行取款大循环;
N/n 直接return,停止所有操作;
其他 continue,继续执行小循环,重复输入Y/N
function func(){
代码开始
console.log("***********欢迎使用ATM机取款业务**********");
验证密码
var i = 1;
for(; i <= 3; i++) {
console.log("请输入密码:");
var pwd = parseInt(prompt("请输入密码:"));
if(pwd == 111111) {
console.log("密码输入正确!");
break;
}
}
if(i > 3) {
如果i大于3,表示3次输入密码全部错误。
console.log("密码错误3次!请取卡!");
return;
}
console.log("************请根据序号进行取款************");
取款操作
var moneySum = 0; 取款总金额
var money = 0; 本次取款金额
while(true) {
console.log("0-手动输入金额");
console.log("1-100元\t\t2-300元\t\t3-500元");
console.log("4-1000元\t\t5-3000元\t\t6-5000元");
console.log("请选择:");
var chooseNum = parseInt(prompt("请选择取款序号0-6:"));
switch(chooseNum) {
case 1:
money = 100;
break;
case 2:
money = 300;
break;
case 3:
money = 500;
break;
case 4:
money = 1000;
break;
case 5:
money = 3000;
break;
case 6:
money = 5000;
break;
case 0:
while(true) {
console.log("请输入取款金额:");
money = parseInt(prompt("请输入取款金额:"));
if(money >= 100 && money <= 1000 && money % 100 == 0) {判断输入的金额是否符合要求,若符合,将跳出死循环,否则一直重输。
break;
} else {
console.log("您输入的金额不合法,");
continue;
}
}
break;
default:
console.log("序号选择错误!");
break;
}
验证总取款金额是否超过20000
if(moneySum + money < 20000) {
console.log("取款成功,本次取款" + money + "元,");
moneySum += money;
console.log("总取款" + moneySum + "元");
} else if(moneySum + money == 20000) {
console.log("取款成功,本次取款" + money + "元,");
moneySum += money;
console.log("总取款" + moneySum + "元");
console.log("今日取款已达上限,情取卡!");
break; 总取款达到20000元总循环结束
} else {
console.log("取款失败!每日取款上限20000元,您已取" +
moneySum + "元,还可取" + (20000 - moneySum) + "元");
}
验证是否继续
while(true) {
console.log("是否继续(Y/N):");
var isGoON = prompt("是否继续(Y/N):");
if(isGoON == 'y' || isGoON == 'Y') {
break; 输入Y/y跳出此死循环,从输入取钱序号处开始循环
} else if(isGoON == 'n' || isGoON == 'N') {
return;输入N/n跳出函数,程序终止
} else {
console.log("输入有误,请选择Y-继续,N-退出,");
}
}
}
console.log("感谢您的使用!");
}
func();调用函数 ,此题结束。
5.函数递归实现1!+2!+3!……+10!=?
var sum=0;
var j=1;
function func(n1){
var j=1;
!function(n2){ 此函数用于实现n!的乘积,n2=1,j=1*1,n2=2,j=j*2,依次类推。
j*=n2;
n2++;
if(n2<=n1){
arguments.callee(n2);
}
}(1)
sum+=j; 用于实现1!+2!+3!……+10!的和,n1=1,sum=1!,n1=2,此时sum=sum+2!,依次类推。
n1++;
if(n1<=10){
arguments.callee(n1);
}
}
func(1);
console.log("和是"+sum);
以上就是我在js学习中遇到的一些比较重要的问题,下周再见。
JS学习中遇到的一些题目的更多相关文章
- 关于 knockout js 学习中的疑问 (1)
最近刚刚学习knockout中遇到如下问题: 1.在给viewModel定义一个方法时,有时后面跟 的this,有的时候没有 如下所示: this.fullName = ko.computed(fun ...
- Vue.js学习笔记:在元素 和 template 中使用 v-if 指令
f 指令 语法比较简单,直接上代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" " ...
- JS学习之DOM节点的关系属性封装、克隆节点、Dom中Style常用的一些属性等小结
JS DOM节点: 在JS DOM中节点的关系被定义为节点的属性: 通常有以下几种节点之间的关系: (这里的关系是所有浏览器都支持的) parentNode 父节点 childNodes ...
- JS学习五(js中的事件)
[JS中的事件分类] 1.鼠标事件 click/bdlclick/onmouseover/onmouseout 2. HTML事件 onload/onscroll/onsubmit/onchange/ ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理
一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...
- js学习之变量、作用域和内存问题
js学习之变量.作用域和内存问题 标签(空格分隔): javascript 变量 1.基本类型和引用类型: 基本类型值:Undefined, Null, Boolean, Number, String ...
- 【Knockout.js 学习体验之旅】(3)模板绑定
本文是[Knockout.js 学习体验之旅]系列文章的第3篇,所有demo均基于目前knockout.js的最新版本(3.4.0).小茄才识有限,文中若有不当之处,还望大家指出. 目录: [Knoc ...
- 【Knockout.js 学习体验之旅】(2)花式捆绑
本文是[Knockout.js 学习体验之旅]系列文章的第2篇,所有demo均基于目前knockout.js的最新版本(3.4.0).小茄才识有限,文中若有不当之处,还望大家指出. 目录: [Knoc ...
随机推荐
- RancherOS 学习笔记(一)
今天只是简单了解下rancheros,以及尝试安装了下. 这是官网文档:http://docs.rancher.com/os/ 这是官网Github地址:https://github.com/ranc ...
- 【转】44款Java 网络爬虫开源软件
原帖地址 http://www.oschina.net/project/lang/19?tag=64&sort=time 极简网络爬虫组件 WebFetch WebFetch 是无依赖极简网页 ...
- CSS1,CSS2选择器详解
第一.CSS1选择器: 1.元素选择器(也叫标签选择器,是最基本的选择器) <style> html{background-color: red;} div{background-colo ...
- 专题:DUILIB Win32 透明效果
Win32 透明效果相关基础知识 Layered Windows 分层窗口.这是Windows2000开始引入的概念,重新定义了窗口的Hit Testing方法,以前都是把窗口按rectangle的方 ...
- Vue基本入门
介绍 1.Vue.js是什么? Vue.js(读音:/vju:/,类似于view)是一套构建用户界面的渐进式框架,与其他重量级框架不同的是,Vue采用的是自底向上增量开发的设计. Vue的核心库只关注 ...
- 算法模板——Dinic最小费用最大流
实现功能:输入M,N,S,T:接下来M行输入M条弧的信息(包括起点,终点,流量,单位费用):实现功能是求出以S为源点,T为汇点的网络最大流的最小费用 其实相当的像Dinic最大流呐= = 还是spfa ...
- 3402: [Usaco2009 Open]Hide and Seek 捉迷藏
3402: [Usaco2009 Open]Hide and Seek 捉迷藏 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 78 Solved: 6 ...
- 1708: [Usaco2007 Oct]Money奶牛的硬币
1708: [Usaco2007 Oct]Money奶牛的硬币 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 544 Solved: 352[Submi ...
- webStorm Linux Ubuntu 中文搜狗输入问题
1 打开安装路径下bin/webstorm.sh vim ~/WebStorm-145.597.6/bin/webstorm.sh 2.在打开文件的最前面加入如下代码: export XMODIFIE ...
- iOS 集成Weex入门教程
前言 自Weex发布伊始, 其口号 "Write Once, Run Everywhere"就吸引了大批前端与客户端程序猿纷纷入坑, 我也不能独善其中. 就我目前所学习Weex的经 ...