JavaScript-数组的浅析(1)

1、以构造数组的形式来构建数组,有以下几种方式

定义一个空的数组:var array1 = new Array();

定义一个长度为20的数组:var array2 = new Array(20);

定义数组是可以直接存入要保存的数据:var array3 = new Array(1,2,3);

定义数组时可以省略new关键字:var array4 = Array (1,2,3);

定义空数组还可以:var array5 = [];

定义一个保存了数据元素的数组:var array6 = [1,2,3];

小节:前四个和最后两个的区别就是后面的两个省略了new 和 Array(A必须大写),方法还比较简洁,但是还得注意括号,后面的是中括号,前面的是小括号。

2、把数组里面的元素提取出来

首先定义一个含有元素的数组:var array = [1,2,3];

想从这里面提取出来我们需要的元素,需要用到下标(就是给数组里面的元素进行编号,方便我们准确提取出来),需要注意的是下标是从0开始的,就我写的这个数组为例,它的下标有3个:0,1,2。

那么,array[0] = 1; array[1] = 2; array[2] = 3;

还需要引入一个新的概念,把超出数组下标范围的操作称之为数组操作的越界(beyond bounds)。就上个例子为例,它的下标只有三个,所以不可能有 array[3]这种情况的出现。

3、Math 的五个应用

求数组中的元素的最小值

var min = Math.min(1,3,5,2);

alert("min:" + min);

求数组中的元素的最大值

var max = Math.max(1,3,5,2);

alert("max" + max);

向上取整方法

var num = Math.ceil(1.8);

alert(num);  输出的结果是2。

向下取整方法

var num = Math.floor(1.8);

alert(num);  输出的结果是1。

四舍五入方法

var num = Math.round(1.8);

alert(num);  输出的结果是2。

做一个小小的练习题

练习一:随机出现10~20之间的1个数

var array = Math.floor(Math.random() * 11 + 10);

console.log(array); 在chrome中的检查部分的console中就可以看到我们想要的结果了。

公式:求任意范围的随机数的方法为:

[a,b]范围内的随机数的公式为:

Math.floor(Math.random() * ( b -a +1 ) + a );

再加一点难度:

练习二:随机出现10~20之间的10个数

var array = [];

for (var i = 0 ; i < 10 ; i++) {

array[i] = Math.floor(Math.random() * 11 + 10 )

}

console.log(array);

解题总结:我就经常容易在这出现错误,第一个就是首先你得在for的外面首先定义一个空的数组,如果定义在for循环里面的话会使得每次循环都是给array重新进行了赋值,输出的结果只有一个数据。第二就是需要给for循环里面的array加上[i],这就相当于给每次循环出现的数字都给了一个下标,方便提取,同时也是为了使每次出现的数据都能赋值到数组中,不然还是只给array进行不断的赋值,出现的还是一个数据。第三,console必须放在最外面,放在里面是把每次赋值的数据显现出来,放在外面能够使最后得到的数组显现出来。

练习三:对练习二得到的十个元素进行求和处理

var array = [];

var sum = 0 ;

for (var i = 0 ; i < 10 ; i++) {

array[i] = Math.floor(Math.random() * 11 + 10 )

sum += array[i];

}

console.log(sum);

这道题很简单,就是在第二道题的基础上加了一个sum元素

练习四:把一个数组内的元素全部复制到另一个数组内

var array = [1,2,3];

var arrayCopy = array;

console.log(arrayCopy);

给两个数组中间直接加上等号,可以使两个数组进行复制。

练习五:生成两个数组,每个数组都有10个元素,元素的取值范围在20~40之间,数组对应元素相加,放到另外一个新的数组中。

var array1 = [ ];

var array2 = [ ];

var array = [ ];

for ( var i = 0 ; i < 10 ; i++) {

array1[i] = Math.floor(Math.random() * 21 + 20 ) ;

array2 [i]= Math.floor(Math.random() * 21 + 20 ) ;

array[i] = array1[i] + array2[i] ;

}

console.log(array);

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • FreeCodeCamp - Basic JavaScript 写在前面: 我曾经在进谷前刷过这一套题,不过当时只...
    付林恒阅读 16,436评论 5 28
  • 第1章 认识JS JavaScript能做什么?1.增强页面动态效果(如:下拉菜单、图片轮播、信息滚动等)2.实现...
    mo默22阅读 1,257评论 0 5
  • .写一个函数,返回从min到max之间的 随机整数,包括min不包括max function randomness...
    邢烽朔阅读 313评论 0 1
  • 某次二面时,面试官问起Js排序问题,吾绞尽脑汁回答了几种,深感算法有很大的问题,所以总计一下! 排序算法说明 (1...
    流浪的先知阅读 1,190评论 0 4
  • 何天昊: 何天昊今天的表现比昨天好的多,身体状况也比昨天好了,内务也能自己整理到位,但还是有拖拉的溜号...
    小鹿z阅读 592评论 1 0