先看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. json数据渲染表单元素出现的问题

    解析页面表单元素 parseForm: function () { var data = {}; $(this).find('input').each(function () { switch ($( ...

  2. EasyUI datagrid默认勾选checkbox时注意事项

    在使用easyui的datagrid默认选中复选框时遇到的一个问题:就是加载程序默认选中复选框时死活选不中,查了好多资料才知道是easyui的datagrid的singleSelect属性设置为‘tr ...

  3. 天方夜谈·数据结构·List

    在战场上杀不死的敌人,永远也别想打败他,他就像幽灵横亘在你失败的田地上. 大一下学期,接触到Java程序设计语言,时至今日,才越发觉得知识与技术的海洋是多么多么的浩瀚.......如果说编程语言的一个 ...

  4. PHP 序列化与反序列化函数

    序列化与反序列化 把复杂的数据类型压缩到一个字符串中 serialize() 把变量和它们的值编码成文本形式 unserialize() 恢复原先变量   1.创建一个$arr数组用于储存用户基本信息 ...

  5. [刷题]算法竞赛入门经典(第2版) 6-7/UVa804 - Petri Net Simulation

    题意:模拟Petri网的执行.虽然没听说过Petri网,但是题目描述的很清晰. 代码:(Accepted,0.210s) //UVa804 - Petri Net Simulation //Accep ...

  6. Linux防火墙的关闭和开启

    1) 重启后生效 开启: chkconfig iptables on 关闭: chkconfig iptables off 2) 即时生效,重启后失效 开启: service iptables sta ...

  7. 纯CSS图片缩放后显示详细信息

    哎~!突然好久没更新博客了,最近总在下雨,晚上也经常没有时间来管理博客(目前在敲自己的一个平台,晢时还在写逻辑层的代码),好吧!废话不多说了,言归正传. 现在很多图片缩放的特效大多数都是用javasc ...

  8. MyBatis源码解读(3)——MapperMethod

    在前面两篇的MyBatis源码解读中,我们一路跟踪到了MapperProxy,知道了尽管是使用了动态代理技术使得我们能直接使用接口方法.为巩固加深动态代理,我们不妨再来回忆一遍何为动态代理. 我相信在 ...

  9. GO的初始简书(一)简介安装

    已经玩了很长一段时间的golang了,做个gopher,下面我将逐步展示各种go语言的开发,从入门开始哦,完全是凭着自己学习和实践的结果展示,如果有说的不对的,请指正. 简介 go语言是由Google ...

  10. 实时语音视频技术webrtc的编译总结

    webrtc编译教程 一.安装depot_tools工具 首先你的电脑上安装了git 1)    下载depot_tools cd到下载的目录下 git clone https://chromium. ...