先看JS循环作业题:

一.一张纸的厚度是0.0001米,将纸对折,对折多少次厚度超过珠峰高度8848米

<script type="text/javascript">
var a=0.0001;
var i=0;
while(a<=8848){
a=a*2;
i++;
}
alert(i); </script>

这个题主要考察的点:1.当要求得到什么效果或者多少次结束时,我们可以考虑运动while语句是比较方便的;

2.对折一次厚度要*2,所以下次折叠后,厚度为上一次的2倍

二.公鸡2文,母鸡1文,小鸡半文,每种至少一只,100文买100只鸡有多少可能性?

通过分析我们可以得到   公鸡最多买49只,母鸡最多97只,小鸡最多194只

<script type="text/javascript">
var i=0;
for(var a=1;a<=49;a++){
for(var b=1;b<=97;b++){
for(var c=1;c<=194;c++){
if((a+b+c==100)&&(a*2+b*1+c*0.5==100)){
i++; }
}
}
}
alert(i);
</script>

分析:1.这个题逻辑考察的是for循环,for循环四要素:初始值-- 循环条件--- 状态改变--- 循环体

2.此外这个题目还考察了逻辑运算符(并:&&)  我们学习的三个逻辑运算符为[并:&&]    [或:||]   [非:!]

三.有一对幼兔,幼兔1个月后长成小兔,小兔1个月后长成成兔并生下一对幼兔,问6个月后有多少对兔子,幼兔、小兔、成兔对数分别是多少?

经分析我们得到:

第0个月:幼兔 1 小兔 0 成兔 0
第1个月:幼兔 0 小兔 1 成兔 0
第2个月:幼兔 1 小兔 0 成兔 1
第3个月:幼兔 1 小兔 1 成兔 1
第4个月:幼兔 2 小兔 1 成兔 2
第5个月:幼兔 3 小兔 2 成兔 3
第6个月:幼兔 5 小兔 3 成兔 5

当前月份幼兔(y) = 上个月的成兔(sc)+上月小兔(sx)
当前月份小兔(x) = 上月幼兔(sy)
当前月份成兔(c) = 上月成兔(sc)+上月小兔(sx)

所以:

<script type="text/javascript">
var y=1;
var x=0;
var c=0;
var sy=0;
var sx=0;
var sc=0;
for(i=1;i<=6;i++){
sy=y;
sx=x;
sc=c;
y=sc+sx;
x=sy;
c=sc+sx;
}
alert(y+","+x+","+c);
alert(i);
</script>

这个题我是有点晕乎的,听到解析后思路瞬间打开了,以后还得注重问题的分析以及语言的逻辑性

JS数组(数据结构)

一.数组的定义方式

方式1:

<script type="text/javascript">
var arr = new Array();-----这一步之后,变量arr变为数组
arr[0]=1;---------------arr[]里面为索引,索引值从0开始
arr[1]=2;
arr[2]=3; alert(arr[0]);
</script>

方式2:

<script type="text/javascript">
var arr = new Array(1,2,3,4,5);
alert(arr[1]);
</script>

方式3:

<script type="text/javascript">
var arr = new Array();
arr.push(1);
arr.push(2);
alert(arr[0]);
</script>

方式4:

<script type="text/javascript">
var arr = [1,2,3,4,5];
alert(arr[2]);
</script>

一般我们只需要掌握方式1和2就好了

特别注意:var arr =new Array();   /*这一步之后,变量arr变为数组*/

arr[a]=...;

1.a的值是索引,所以的值从0开始
2.数组的索引叫做(key),数组里面存的值叫做(value).
3.key和value是成对存在的,叫做(键值对)

二.强类型语言三个特点(弱类型语言“JS”可以不遵循,灵活性高):

1.数组存储必须是连续的;

2.数组必须规定长度;

3.必须要规定存储的类型

三.数组长度

1.强类型语言:var arr =new Array(5);    /*表示数组长度是5,了解内容*/

2.弱类型语言可以存储任何类型的数据(既能存整数,又能存字符串,还能存别的数据)

<script type="text/javascript">
var arr = new Array();
arr[0]=1;
arr[1]=2;
arr[2]="hello";
alert(arr[2]); </script>

3.数组长度  length

<script type="text/javascript">
var arr = [1,2,3,4,5,6];
alert(arr.length);
</script>

4.其他

arr.length;     代表属性
arr.push();    代表方法

四.二维数组(相当于excel表格中的第几行第几列代表的数据,映射成一个表格)

<script type="text/javascript">
var arr = new Array(
new Array(11,12,13,14,15),
new Array(21,22,23,24,25),
new Array(31,32,33,34,35)
); alert(arr[0][4]);
</script>

五.遍历数组

1.for循环

<script type="text/javascript">
var arr = new Array(62,31,11,7,18,20,11);
for(var i=0;i<arr.length;i++){
alert(arr[i]);
}
</script>

注意:1.共跳转7次,在这里我们需要循环条件为   i<arr.length

2.for循环是匹配数组的

3.在数组中必须保证arr(var  i=0;)开始

2.foreach循环(在强类型语言中运用,在JS语言中没有foreach)

在JS用法

<script type="text/javascript">
var arr = new Array(62,31,11,7,18,20,11);
for(var a in arr){
alert(arr[a]);
}
</script>

这样运用foreash循环结果和上面for循环结果是一致的

JS数组+JS循环题的更多相关文章

  1. JS: 数组的循环函数

    JS 数组相关的循环函数,用得挺多,所以有些坑还是要去踩一下,先来看一道面试题. 注意:下面提到的不改变原数组仅针对基本数据类型. 面试题 模拟实现数组的 map 函数. 心中有答案了吗?我的答案放在 ...

  2. js数组试列题

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  3. C#数组、js数组、json

    C#数组 参考地址C#之数组 什么是数组?数组是一种数据结构,包含同一个类型的多个元素.数组的声明:int[] myIntArray; 注:声明数组时,方括号 [] 必须跟在类型后面,而不是变量名后面 ...

  4. 2017年9月22日 关于JS数组

    JS数组 JS数组的定义方法 var arr = []; var arr = new Array() JS数组属性 长度 arr.length 遍历数组 索引值:从0开始数 第一种方法 for(var ...

  5. json、js数组真心不是想得那么简单

    之前因为做前台的东西比較少,对于json和js数组的认识仅局限于一种固定格式.这样的固定的思维在开发前台时,特别是近期使用highcharts插件时.让我感到特别不明确.通过查询最终心头的疙瘩解开了. ...

  6. 页面循环绑定(变量污染问题),js面向对象编程(对象属性增删改查),js字符串操作,js数组操作

    页面循环绑定(变量污染问题) var lis = document.querySelectorAll(".ul li") for ( var i = 0 ; i < lis. ...

  7. js中数组的循环与遍历forEach,map

    对于前端的循环遍历我们知道有 针对js数组的forEach().map().filter().reduce()方法 针对js对象的for/in语句(for/in也能遍历数组,但不推荐) 针对jq数组/ ...

  8. JS基础与循环

    JS 简介 [JS的三种方式] 1.HTML标签中内嵌JS <button onclick="javascript:alert('白痴')">呵呵呵</butto ...

  9. 深入理解Js数组

    深入理解Js数组 在Js中数组存在两种形式,一种是与C/C++等相同的在连续内存中存放数据的快数组,另一种是HashTable结构的慢数组,是一种典型的字典形式. 描述 在本文中所有的测试都是基于V8 ...

随机推荐

  1. 浅谈JavaScript时间与正则表达式

    时间函数:var box = new Date() 函数       Demo:         alert(Date.parse('4/12/2007'));    //返回的是一个毫秒数11763 ...

  2. Linux中批量添加文件和修改文件小笔记

    1.#使用通配符批量创建5个文件 $ touch file{1..10}.txt 2.#批量修改这五个后缀名为.txt的文本文件名重命名为.c后缀名结尾的文件 $ rename 's/\.txt/\. ...

  3. WPF 自定义ColorDialog DropDownCustomColorPicker

    今天分享一个 WPF 版的ColorDialog,该控件源自 这里,不过笔者已经该控件做了大量的修改工作,以适应自己的产品需求,闲话少说,先看看效果图: 1.DropDownCustomColorPi ...

  4. springboot(十二):springboot如何测试打包部署

    有很多网友会时不时的问我,spring boot项目如何测试,如何部署,在生产中有什么好的部署方案吗?这篇文章就来介绍一下spring boot 如何开发.调试.打包到最后的投产上线. 开发阶段 单元 ...

  5. Web 版 PowerDesigner (Canvas) 技术

    什么是 Canvas?    HTML5 的 canvas 元素使用 JavaScript 在网页上绘制图像. 画布是一个矩形区域,您可以控制其每一像素. canvas 拥有多种绘制路径.矩形.圆形. ...

  6. 网络编程:I/O复用

    I/O多路复用是在多线程或多进程编程中常用技术.主要是通过select/epoll/poll三个函数支持的.在此主要对select和epoll函数详细介绍. select函数 该函数运行进程指示内核等 ...

  7. 在Centos7 更改Docker默认镜像和容器的位置

    图片出处:https://bobcares.com/wp-content/uploads/docker-change-directory.jpg 一.Why? 通常,当你开始使用docker时,我们并 ...

  8. [刷题]算法竞赛入门经典 3-1/UVa1585 3-2/UVa1586 3-3/UVa1225

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO(我也是在网上找到的pdf,但不记得是从哪里搜刮到的了,就重新上传了一遍) PS:第一次写博客分享我的代码,不知道我对c ...

  9. PHP 类的封装和使用

    类:相似的数据和数据操作的封装  class 成员量:普通的量加上一定的修饰就变成了成员量 public,protected,private 成员方法:普通的函数,加上一定的修饰,放入到类中就变成了成 ...

  10. Welcome to my Blog

    Only English? Oh my god!!! why open live write can't write by Chinese?