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是个很大的数组时 ...
随机推荐
- 初学Log4Net
1.Log4Net是什么? Log4Net是用来记录日志的,可以将程序运行过程中的信息输出到一些地方(文件.数据库.EventLog等) 2.Appender Appende ...
- web安全—浏览器的进制
浏览器的进制 字符的ascii码值可以转化为进制形式.可以用来绕过XSS filter. HTML属性值中的进制使用 .十进制使用a 表示,&#作为前缀,;作为后缀,后缀也可以没有. 如果要使 ...
- MySQL修改表字段相关信息
昨天收获颇多,首先回顾一下有关mysql的内容. 我在查询表信息时,出现了 empty set 0.00 sec 的错误,我很奇怪,仔细检查发现原来是表字段名称写错了, 于是我想修改字段名称,经过查询 ...
- crontab定时任务不执行的原因
1.重启crontab若是遇见"You (cloudlogin) are not allowed to use this program (crontab) ...
- [.NET] 《Effective C#》快速笔记 - C# 中的动态编程
<Effective C#>快速笔记 - C# 中的动态编程 静态类型和动态类型各有所长,静态类型能够让编译器帮你找出更多的错误,因为编译器能够在编译时进行大部分的检查工作.C# 是一种静 ...
- 0基础搭建Hadoop大数据处理-集群安装
经过一系列的前期环境准备,现在可以开始Hadoop的安装了,在这里去apache官网下载2.7.3的版本 http://www.apache.org/dyn/closer.cgi/hadoop/com ...
- Java学习笔记——山西煤老板蛋疼的拉车问题
小荷才露尖尖角,早有蜻蜓立上头 --小池 这个问题是这样描述的: 山西煤老板有3000吨煤,要运到1000km公里外的地方卖.他选择使用火车来运煤,每辆火车行驶一公里将消耗一吨煤,且火车载货上限为10 ...
- SSH抛出org.apache.ibatis.exceptions.PersistenceException: 异常
抛出的异常类容如下 如果遇到这个异常,那么肯定是你在配置事物切面时出错,或者是你的写的事物的方法名称没有和这里的配置对应: 你需要注意如下几点: 1.你的名称必须是以英文开头 2.在你用着事物方法的名 ...
- Android官方架构组件介绍之LifeCycle
Google 2017 I/O开发者大会于近日召开,在开发者大会上谷歌除了发布了Android O等一些新产品之外,也对Android代码的架构做出了一个官方的回应. Google 2017 I/O开 ...
- Struts2 设置global timer
设置全局的timer需要在web.xml中添加servlet, 并设置load-on-startup 为 1, 然后在servlet的init()中开启timer, 具体代码如下: 1. web.xm ...