数组

//数组
// var array = new Array();
// array[0]="zs";
// array[1]="ls";
var name = "ml"
var array =["zs","ls","mw"];
console.log(array[0]);
console.log(array.length); for (let index = 0; index < array.length; index++) {
const element = array[index];
console.log(element);
}

输入 0-100 的数组

var array=[];
console.log(array.length);
for (let index = 0; index <=100; index++) {
array[index] = index;
}
console.log(array);

数组的 length

数组中的值如果没有赋值,就是 undefined。

//数组输出 0-100 的所有的奇数的数字
//方法一:
var array = [];
var j = 0;
for (let index = 1; index <= 100; index++) {
if (i % 2 !== 0) {
array[j] = i;
j++;
}
}
console.log(array); // 方法二
//每当我们忘数组中新增一个项,都会更改length属性
var array = [];
for (let index = 1; index <= 100; index++) {
if (i % 2 !== 0) {
array[array.length] = i;
}
}

0-100 中能被 3 整除的数,输出出来,一共有多少个。

var array=[];
for (let index = 1; index <= 100; index++) {
if (index %3 ==0) {
array[array.length]=index; }
}
console.log(array);
console.log(array.length); array.length = 1;
console.log(array);

第一次运行的时候 length = 0,也就是第一位是 index。第二次运行的时候,length = 1。

数组:数据的有序列表。可以存放任意类型的数据,数组的大小可以动态调整。

创建数组两种方式:

方式1:数组字面量

var arr1 = [];
var arr2 = [1,2,3];

方式2:Array 的构造函数

var arr3 = new Array(); //创建一个空数组
var arr4 = new Array(10); //创建一个长度为 10 的数组
var arr5 = new Array("a","b","c"); //创建一个包含 3 个字符串的数组

一个数组 ["abc", "aaa", "aaa"]; 输出 abc|aaa|aaa

//abc|aaa|aaa
var array = ["abc", "aaa", "aaa"];
var sperator = "|";
var str = array[0];
for (let index = 1; index < array.length; index++) {
str += sperator + array[i];
}
console.log(str);

当需要合成一个新的数组的时候,可以巧妙的运用array.length 来避免造成数组的 index 未定义,出现 undefined。

一题经典的冒泡排序:

var array = ["13", "43", "53", "1", "41", "65"]
//控制循环次数
var s = 0;
var s1 = 0;
//为什么isSort = true 不能写在外循环
//因为 交换位置 isSort = false。 isSort 的值永远是 false。
//我们要检测的是某一趟是否交换位置
for (var i = 0; i < array.length - 1; i++) {
var isSort = true; //假设排序ok
//控制两两比较的次数
for (var j = 0; j < array.length - 1 - i; j++) {
//两两比较 从小到大
var isSort = false;
// 如果交换位置,说明还没有排序好,如果不交换位置,说明排序好
if (array[j] > array[j + 1]) {
//交换位置
var tmp = array[j];
array[j] = array[j + 1];
array[j + 1] = tmp;
}
s++; //记录内循环次数
}
s1++; //记录外循环次数
if (isSort) {
//如果排序好了
break;
}
}
console.log(s);
console.log(s1);
console.log(array);
console.log(array.length);

运用了一个检测是否排序完成的 isSort 来减少比较次数。

javascript_09-数组的更多相关文章

  1. javascript中的Array对象 —— 数组的合并、转换、迭代、排序、堆栈

    Array 是javascript中经常用到的数据类型.javascript 的数组其他语言中数组的最大的区别是其每个数组项都可以保存任何类型的数据.本文主要讨论javascript中数组的声明.转换 ...

  2. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  3. 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)

    建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...

  4. 了解PHP中的Array数组和foreach

    1. 了解数组 PHP 中的数组实际上是一个有序映射.映射是一种把 values 关联到 keys 的类型.详细的解释可参见:PHP.net中的Array数组    . 2.例子:一般的数组 这里,我 ...

  5. JavaScript权威指南 - 数组

    JavaScript数组是一种特殊类型的对象. JavaScript数组元素可以为任意类型,最大容纳232-1个元素. JavaScript数组是动态的,有新元素添加时,自动更新length属性. J ...

  6. JavaScript常见的五种数组去重的方式

    ▓▓▓▓▓▓ 大致介绍 JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结 先来建立一个数组 var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN ...

  7. js:给定两个数组,如何判断他们的相对应下标的元素类型是一样的

    题目: 给Array对象原型上添加一个sameStructureAs方法,该方法接收一个任意类型的参数,要求返回当前数组与传入参数数组(假定是)相对应下标的元素类型是否一致. 假设已经写好了Array ...

  8. javascript数组查重方法总结

    文章参考地址:http://blog.csdn.net/chengxuyuan20100425/article/details/8497277 题目 对下列数组去重: var arr = ['aa', ...

  9. 掌握javascript中的最基础数据结构-----数组

    这是一篇<数据结构与算法javascript描述>的读书笔记.主要梳理了关于数组的知识.部分内容及源码来自原作. 书中第一章介绍了如何配置javascript运行环境:javascript ...

  10. 小兔JS教程(四)-- 彻底攻略JS数组

    在开始本章之前,先给出上一节的答案,参考答案地址: http://www.xiaotublog.com/demo.html?path=homework/03/index2 1.JS数组的三大特性 在J ...

随机推荐

  1. 生成有目录的pdf

    生成有目录的pdf 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考文献 https://jingyan.baidu.com/article/ff411625c2153512e48237a ...

  2. Linux系统调优——CPU(一)

    (1).系统调优思路 性能优化就是找到系统处理中的瓶颈以及去除这些的过程,性能优化其实是对OS 各子系统达到一种平衡的定义.具体步骤如下: 1. 系统的运行状况:  CPU -> MEM  -& ...

  3. java 特殊字符处理

    // 去除富文本中的html标签 // <p>段落替换为换行 content = content.replaceAll("<p .*?>", "\ ...

  4. easyui前台改变datagrid某单元格的值

    有时候前台完成某个操作后要修改datagrid的值, 也许这个datagrid是没有保存的, 所以要修改后才能传递到后台; 也许要其他操作过后才需请求后台; 这些情况都需要前台对datagrid的单元 ...

  5. 【JS】实用/常用函数/Function方法

    1.获取日月 时分秒 //获取 月日 getMonth=(time)=>{ var date = new Date(time) <?):(date.getMonth()+) ?'+date ...

  6. 三、部署DNS

    通常情况下配置好域后,DNS会默认安装好,但有时候这个DNS只能解析域控的域名,不能解析其他域名,比如baidu.com之类的.此时需要配置转发器,把不能解析的域名转到其他DNS配置如下: 打开DNS ...

  7. 使用TypeScript创建Vue项目

    Vue的灵活性总是让代码看起来非常洗练,对TypeScript来说也是一种挑战, 好在Vue对TypeScript进行了一次全方位的适配. 相对于React严谨的代码,Redux啰嗦的样板代码,Vue ...

  8. Python35之包的创建

    包(package) 一.创建一个文件夹,用于存放相关的模块,文件夹的名字即包的名字 二.在文件夹中创建一个__init__.py的模块文件,内容可以为空 三将相关的模块放入文件夹中 这样就相当于创建 ...

  9. 小程序--e.target和e.currentTarget区别

    事件捕获与事件冒泡 事件捕获是从外到内,事件冒泡是从内到外. 注意:不管是不是冒泡事件,都不会改变事件传递的参数值,都还是在dataset中获取(******) target:指事件源组件对象    ...

  10. 接口缓存--把接口放在redis数据库中,减少访问量

    针对访问量大,且数据较固定的接口,建议建立接口缓存,建立了缓存之后,不会再直接去访问接口了. 比如下面的轮播图接口,每刷新一下首页都会访问一下轮播图接口,所以我们用接口缓存来处理,减少访问量. 视图模 ...