js数组及数组应用(冒泡和二分,遍历输出)
一、定义:1)var arr=new Array();
加数据:arr[0]=1;
2)定义同时赋值:var arr=new Array(1,2,3,4,5);
3)调用:var arr=new Array();
arr.push(1);用.push调用
4)var arr=[1,2,3,4,5];
alert(arr[4]);
二、属性:1)arr.length:数组的长度
eg:var arr=new Array(1,2,3,4,5,6);
alert(arr.length);

arr.length;属性(国定)
arr.push:方法(不固定)
2)arr.indexOf:判断数组中是否存在输入的这个数据,若返回索引则存在,返回-1则不存在
eg:var arr=new Array(1,2,3,4,5,6);
var a=3;
alert(arr.indexOf(a));

二维数组:数组外面又套了一个数组
var arr=new Array(
var arr=new Array(1,2,3,4,5,6);
var arr=new Array(11,12,13,14,15,16);
);
三、遍历输出:1、for循环
var arr=new Array(10,20,11,14,18,30,50);
for(var i=0;i<arr.length;i++)
{
alert(arr[i]);
}







2、foreach:强类型中不用与数组,用于集合
arr int 集合遍历
数组索引叫做key,数组里面的值叫做value,key和value是成对存在的,叫做键值对
冒泡:比较的轮次是数组长度减一,比较的次数是数组长度减轮次
var arr=new Array(70,34,60,49,20,59,98,100);
var zj=0;
第一次for用来控制循坏轮数
for(var i=1;i<arr.length;i++)
{
for(var a=0;a<arr.length-i;a++)控制每轮比较次数;
{
if(arr[a]<arr[a+1])
{
arr[a]=zj;
arr[a+1]=arr[a];
zj=arr[a+1];
}
}
}
二分法:在一个数组中查找数据,找到数据所在位置的索引
var arr =new Array(1,2,3,4,5,6,7,8,9,10);
var a=3;
var maxd=arr.length-1;mind=0;
while(true){
var zjd=parseInt((maxd+mind)/2);
if(zjd==minx){
if(a==arr[zjd+1]){
alert(zjd+1);
break;
}
}
if(a==zjd){
alert(zjd);
break;
}else if(a>zjd){
mind=zjd;
}else{maxd=zjd;}
}
js数组及数组应用(冒泡和二分,遍历输出)的更多相关文章
- js二维数组与字符串
1. 二维数组:数组中的元素,又引用了另一个数组对象 何时使用:只要保存横行竖列的数据, 具有上下级包含关系的数据, 创建二维数组: 1. var arr=[]; col arr[0]=[" ...
- JS数组追加数组采用push.apply的坑
JS数组追加数组没有现成的函数,这么多年我已经习惯了a.push.apply(a, b);这种自以为很酷的,不需要写for循环的写法,一直也没遇到什么问题,直到今天我要append的b是个很大的数组时 ...
- JS Jquery去除数组重复元素
js jquery去除数组中的重复元素 第一种:$.unique() 第二种: for(var i = 0,len = totalArray_line.length;i < len;i++) { ...
- 多动手试试,其实List类型的变量在页面上取到的值可以直接赋值给一个js的Array数组变量
多动手试试,其实List类型的变量在页面上取到的值可以直接赋值给一个js的Array数组变量,并且数组变量可以直接取到每一个元素var array1 = '<%=yearList =>'; ...
- js中的数组
上网查了一下,js中的数组包含的内容还真不少.先给出两个学习的链接: w3school链接:http://www.w3school.com.cn/js/js_obj_array.asp 博客园链接:h ...
- JS与PHP数组操作的不同
JS与PHP数组操作的不同 1.JS 中向数组中添加元素,必须指定下标 2.php中向数组中添加元素,可以不指定下标(追加) 3.JS 中数组元素的下标,是连续 4.PHP中数组元素的下标,可以不连续 ...
- 关于 js 2个数组取差集怎么取
关于 js 2个数组取差集怎么取? 例如求var arr1 = [1]; var arr2 = [1,2];的差集方法一: Array.prototype.diff = function(a) { r ...
- 有几数组表单,js怎么获得数组并动态相加输出到文本框
有几数组表单,js如何获得数组并动态相加输出到文本框<input name= "fee1[] "> <input name= "fee2[] & ...
- JS数组追加数组采用push.apply的坑(转)
JS数组追加数组没有现成的函数,这么多年我已经习惯了a.push.apply(a, b);这种自以为很酷的,不需要写for循环的写法,一直也没遇到什么问题,直到今天我要append的b是个很大的数组时 ...
随机推荐
- git 设置不需要输入密码, 去除 fetch / pull 代码每次都需要输入密码的烦恼
https方式每次都要输入密码,按照如下设置即可输入一次就不用再手输入密码的困扰而且又享受https带来的极速 设置记住密码(默认15分钟): git config --global credenti ...
- VirtualBox实现内外网络互访问的配置
作者 jrl137824675 来源地址:http://www.2cto.com/os/201205/133370.html 环境: 宿主机操作系统 Windows XP s ...
- Java Web实现IOC控制反转之依赖注入
控制反转(Inversion of Control,英文缩写为IoC)是一个重要的面向对象编程的法则来削减计算机程序的耦合问题,也是轻量级的Spring框架的核心. 控制反转一般分为两种类型,依赖注入 ...
- 我拖拖拖--H5拖放API基础篇
不要搞错,本文不是讲如何拖地的.看过<javascript精粹>朋友应该知道,他实现拖放的过程比较复杂,现在时代不同了,我们用H5的新的拖放API就能非常方便的实现拖放效果了.最近在园子见 ...
- (知识点)JS获取网页高度
网页可见区域的宽:document.body.clientWidth 网页可见区域的高:document.body.clientHeight 网页可见区域的宽:document.body.offset ...
- Oracle正则表达式之匹配网址
利于正则表达式匹配出网址 --1 表准备create table test_regexp( object varchar2(50)); --2 数据准备 insert into test_regexp ...
- Ubuntu下如何解压各类文件
tar解包:tar xvf FileName.tar打包:tar cvf FileName.tar DirName(注:tar是打包,不是压缩!)---------------.gz解压1:gunzi ...
- [刷题]算法竞赛入门经典(第2版) 5-1/UVa1593 - Alignment of Code
书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,0 ms) //UVa1593 - Alignment of Code #include&l ...
- 【19道XSS题目】不服来战!
记得第一次接触xss这个概念是在高中,那个时候和一个好基友通过黑客X档案和黑客手册.第一次接触到了除了游戏以外的电脑知识,然后知道了,原来电脑除了玩游戏还可以搞这些,从此两人一发不可收拾的爱上了玩黑这 ...
- SQL Server中INNER JOIN与子查询IN的性能测试
这个月碰到几个人问我关于"SQL SERVER中INNER JOIN 与 IN两种写法的性能孰优孰劣?"这个问题.其实这个概括起来就是SQL Server中INNER JOIN与子 ...