一、一维数组

1.一维数组

var weights = [3,5,1,3.4,2,50];
var all_weight=0;
var avg_weight=0;
for(var i=0;i<weights.length;i++)
{
all_weight + =weights[i];
}
avg_weight=all_weight/weights.length;
//var num = new Number(avg_weight);
document.writeln("总体重是"+all_weight+"平均体重是:"+avg_weight.toFixed(2));

如果你想知道,数据类型
window.alert(avg_weight.constructor);
js中的数组,可以存放各种数据类型(数值、字符串)

数组的细节:
基本用法:
var 数组值 = [元素值1,元素值2...];
1.1数组中的值可以是任意类型的。

var num = ["helo",12,35.12];

1.2数组在内存中存在的形式:
js中的数组是引用传递

递归示例:

function abc(num1){
if(num1>3){
abc(--num1);
}
document.writeln(num1);
}
abc(5);

1.3 值传递与引用传递的区别

1.3.1 值传递

var myval =900; //在内存中新开一块区域
function abc(val){ //内存栈中新开一块区域,把myval的值复制一份副本传递给abc这个

方法的形参val
val = 90;
}
abc(myval);

1.3.2 引用传递

var myarr=[456,90,900];
fuction abc2(arr){
arr[0] = 35;
}
abc2(myarr);
for(var i=0;i<myarr.length;i++)
{
document.writeln(myarr[i]);
}

数组的引用
基本用法:
数组的名称[下标];
比如:
var a = [23,"hello",4.5];
我们访问 a[2] 则输出 4.5
如果我们访问 a[3] 则输出 undefine
结论:不能访问不存在的元素,数组下标是从0开始编号的。

1.4 js的数据可以动态增长

var a = [2,34];
alert(a.length);
a[2] = 56;
alert(a.length);
a[3] = "hell";
alert(a.length);

1.5 js数组的几个重要的应用

数组名.length
拆分字符串 字符串.split(拆分标准)

对字符串分割,生成一个字符串数组:

var str = "hello world abc 顺平";
var arr = str.split(" ",3);
for(var i=0;i<arr.length;i++)
{
document.writeln(arr[i]);
}

遍历数组还可以这样写:

var arr =[45,90,0,"hello"];
arr['gg'] = 900; // arr[0]  arr[1]   arr[2]  arr[3] arr['gg']
for(var key in arr)
{
alert(key + "=" + arr[key]);
}

二、二维数组

var arr=[["shunping",10.23,12],["a","b","c"]];
for(var i=0;i<arr.length;i++)
{
for(var j=0;j<arr[i].length;j++)
{
document.writeln(arr[i][j] +"&nbsp;");
}
document.writeln("<br/>");
}

三、排序查找

3.1 冒泡排序

      var arr = [5,0,-56,900,12,35];
//var arr = [ 1,2,3,34,44,94]
var flag = false;
for(var i=0;i<arr.length-1;i++)
{
document.writeln("大循环...<br/>");
for(var j=0;j<arr.length-1-i;j++)
{
if(arr[j]>arr[j+1])
{
var temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
flag = true;
}
} if(flag){
flag = false;
}else{
break;
}
} //输出排序后的数组:
for(var i=0;i<arr.length;i++)
{
document.writeln(arr[i]);
}

3.2 二分查找:
前台条件:该数组是有序的,不过不是有序的数组,不能使用二分查找。

代码:

var arr = [1,4,6,8,9,90,900];
//思路:找到数组的中间数(midVal),和你要查找的数(findVal)进行比较,如

果//midVal>findVal,则说明findVal在数组的左边,就把该数组二分(就在左边查找)

    var arr = [1,4,6,8,9,90,900];
function binarySearch(arr,findVal,leftIndex,rightIndex){
//防止无穷递归 if(leftIndex>rightIndex)
{
document.writeln("找不到");
return;
} //找到中间值
var midIndex = Math.floor((leftIndex + rightIndex)/2);
var midVal = arr[midIndex]; //比较
if(midVal>findVal){
//在左边找
binarySearch(arr,findVal,leftIndex,midIndex-1);
}else if(midVal<findVal){
//在右边找
binarySearch(arr,findVal,midIndex+1,rightIndex);
}else{
document.writeln("找到下标为" + midIndex);
return;
}
} //测试
binarySearch(arr,2,0,arr.length-1);

四、矩阵转置

//矩阵转置:就是行列互换
/* 2 4 6 8
8 9 0 -1
9 6 2 1 */ var arr = [[2,4,6,8],[8,9,0,-1],[9,6,2,1]];
var arr2 = []; //初始化,定下有多行
for(var i=0;i<arr[0].length;i++){
arr2[i] = [];
} //动态添加数组中的数据
for(var i=0;i<arr.length;i++)
{
for(var j=0;j<arr[i].length;j++)
{
arr2[j][i] = arr[i][j];
}
} //遍历数组
for(var i=0;i<arr2.length;i++)
{
for(var j=0;j<arr2[i].length;j++)
{
document.writeln(arr2[i][j] + "&nbsp;");
}
document.writeln("<br/>");
}

Javascript 基础--数组的更多相关文章

  1. JavaScript 基础数组循环和迭代的几种方法

    JavaScript 数组循环和迭代   (之前一直没怎么注意数组循环,今天做一道题时,用到forEach循环发现它并没有按照我想象的样子执行,总结一下数组循环) 一.第一种方法就是for()循环   ...

  2. JavaScript基础-----数组(Array)

    1.JavaScript 中创建数组的方法: (1).使用Array构造函数: var arr = new Array(); //创建一个空数组 var arr = new Array(5); //传 ...

  3. JavaScript基础数组的字面声名法(010)

    1.两种方法的对比 数组在JavaScript中,就像大多数的其它语言 一样,是对象.我们可以使用JavaScript内置的数组构造函数Array()来创建数组.就象对象的字面声名法一样,数组也可以采 ...

  4. JavaScript基础数组_布尔值_逻辑运算等(2)

    day51 参考:https://www.cnblogs.com/liwenzhou/p/8004649.html 布尔值(Boolean) 区别于Python,true和false都是小写. var ...

  5. JavaScript基础——数组

    一 .数组的介绍 1.概念:数据的集合,任何数据都可以放在数组中 2.作用:可以同时操作多个数据 3.数组的创建: 字面量:var arr = [ ]; 构造函数:var arr = new Arra ...

  6. JavaScript基础------数组

    数组1.数组的每个元素都可以保存任意类型数据2.数组长度可以随之调整创建数组的2种方式 1.使用Array构造函数 语法 new Array() 小括号()说明: (1)预先知道数组要保存的项目的数量 ...

  7. JavaScript基础插曲—元素样式,正则表达式,全局模式,提取数组

    JavaScript基础学习 学习js的基础很重要,可以让自己有更多的技能.我相信这个以后就会用到. Eg:点击选择框,在div中显示出选择的数量 window.onload = function() ...

  8. JavaScript 基础回顾——数组

    JavaScript是无类型语言,数组元素可以具有任意的数据类型,同一个数组的不同元素可以具有不同类型.数组的元素设置可以包含其他数组,便于模拟创建多维数组. 1.创建数组 在JavaScript中, ...

  9. javascript基础知识-数组

    1.javascript创建数组时无需声明数组大小或者在数组大小变化时重新分配 2.javascript数组是无类型的 3.数组元素不一定要连续 4.针对稀疏数组,length比所有元素的索引都要大 ...

随机推荐

  1. C++ Primer 第三章 标准库类型vector+迭代器iterator 运算

    1.vector: 标准库类型vector表示对象的集合,其中所有对象的类型都相同,集合中的每个对象都有一个与之对应的索引,索引用于访问对象.因为vector“容纳着”其他对象,所以它也常被称作容器( ...

  2. Difference between Hard Clip(H) and Soft Clip(S) in Samtools CIGAR string

    一般人都知道 H 和 S 的表面上的区别,即 S 就是 soft, H 就是 hard,S 后,序列里还是会保留序列的信息,而 H 则不会. ----------------------------- ...

  3. ADO

    目 录 第1章 基础    1 1.1 引入ADO库文件    1 1.1.1 版本    1 1.2 初始化OLE/COM库环境    2 1.3 comdef.h    2 1.3.1 字符串编码 ...

  4. Windows文本文件编码

    目录 1 ANSI编码    2 2 UTF16BE编码    2 3 UTF16LE编码    2 4 UTF-8编码    2 5 BOM    3 6 乱码    3 7 总结    5 如下图 ...

  5. 腾讯云从零部署nodejs站点

    版权声明:本文由袁飞翔原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/176 来源:腾云阁 https://www.qclo ...

  6. 【转】 Linux 线程同步的三种方法

    线程的最大特点是资源的共享性,但资源共享中的同步问题是多线程编程的难点.linux下提供了多种方式来处理线程同步,最常用的是互斥锁.条件变量和信号量. 一.互斥锁(mutex) 通过锁机制实现线程间的 ...

  7. Windows日志查看工具合集

    欢迎关注我的社交账号: 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://github.com/jiangxincode 知乎地址 ...

  8. Android 反编译apk 详解

    测试环境: win 7 使用工具: CSDN上下载地址: apktool (资源文件获取)  下载          dex2jar(源码文件获取) 下载        jd-gui  (源码查看)  ...

  9. DOM事件流

    DOM事件标准定义了两种事件流:Capture(捕获)和Bubbing(冒泡):捕获和冒泡是javascript针对dom事件处理的先后顺序,所谓的先后顺序是指针对父标签与其嵌套子标签,如果父标签与嵌 ...

  10. IOS开发设计思路

    我在做 iOS 开发的时候,发现自己在写程序的时候,常常处于两种状态的切换,我把这两种状态称为软件开发的上帝模式与农民模式.我先给大家介绍一下这两种模式的特点. 上帝模式 处于上帝模式时,我需要构思整 ...