数组提升效率的几种操作

let arr = [2, 4, 6, 8, 6, 2]

1.数组置空
如果使用arr = [ ] :之前数组的内容依旧保存在内存中,数据较大时,会导致内存泄漏

 arr.length = 0
 console.log(arr) //[]

2.头部插入数据
concat:合并数组,不会更改现有数组,而是返回一个新数组。

let newArr = [9].concat(arr)
console.log(newArr)    //[9, 2, 4, 6, 8, 6, 2]

3.在尾部插入数据

arr[arr.length] = 4
console.log(arr)  //[2, 4, 6, 8, 6, 2, 4]

4.数组去重

console.log(new Set(arr));     //{ 2, 4, 6, 8 }
//对象转数组
console.log(Array.from(new Set(arr)));  //[ 2, 4, 6, 8 ]

5.复制数组 简单类型:深拷贝

obj = {
	age: 18,
	name: '小米',
	address: {
	 city: '广东'
	}
}
let test = [...arr]
console.log(test);
let nweObj = { ...obj }
console.log(nweObj);
//将数组转换成对象
let obj = { ...arr }
console.log(obj);  //{0: 2, 1: 4, 2: 6, 3: 8, 4: 6, 5: 2}

6.数组交集

let arr2 = ['张三', '李四', '王五', '赵六', '张三', '李四']
let arr3 = ['小米', '小明', '小红', '小绿', '张三', '李四']
jiao = [...new Set(arr2)].filter(item => arr3.includes(item))  
console.log(jiao);  //[ '张三', '李四' ]

7.获取数组的随机值

console.log(arr[Math.floor(Math.random() * arr.length)]);

8.获取最后出现的下标

console.log(arr.lastIndexOf(6));  //4

9.实现字符串倒序

let str = 'abcdefg'
console.log(str.split('').reverse().join(''));

10.替换任意的位置 splice会改变原始数组

let arr2 = ['张三', '李四', '王五', '赵六', '张三', '李四']
arr2.splice(1, 3, '替换值1', '替换值2', '替换值3',)
console.log(arr2);     //[ '张三', '替换值1', '替换值2', '替换值3', '张三', '李四' ]
arr2.splice(0, 1)   //不传入第三位及以后的值时代表删除数据
console.log(arr2);

11.遍历数组

let list = [
  { name: '小米', age: 11 },
  { name: '小明', age: 12 },
  { name: '小红', age: 13 }
]
Array.from(list, (item) => item.str = `名字:${item.name}, 年龄:${item.age}`)
console.log(list); //[
            //   { name: '小米', age: 11, str: '名字:小米, 年龄:11' },
            //   { name: '小明', age: 12, str: '名字:小明, 年龄:12' },
             //   { name: '小红', age: 13, str: '名字:小红, 年龄:13' }
           // ]

12.去掉数据中的虚假值 ’ '不是虚假值

let arr4 = ['小米', '', false, ' ', undefined, 0, NaN, true]
console.log(arr4.filter(Boolean));  //[ '小米', ' ', true ]

13.数组求和

let arr2 = ['张三', '李四', '王五', '赵六', '张三', '李四']
console.log(arr2.reduce((a, b) => a + b));  //'张三李四王五赵六张三李四'
console.log(arr.reduce((a, b) => a + b));   //28
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
第九章 数组 9.1 理解数组 C语言数组是一个由若干同类型数据组成的集合,数组由连续的存储单元组成,最低地址对应于数组的第一个元素,最高地址对应于最后一个元素。 9.2 一维数组 9.2.1 一维数组定义 定义形式: 类型说明符 数组名[常量表达式] 类型说明符是任一种基本数据类型或构造数据类型。数组名是用户定义的数组标识符。方括号中的常量表达式表示数据元素的个数,也称为数组的长度,数组中每个成员称为数组元素。 对于数组的说明: (1)类型说明符实际上是指数组元素的类型。 (2)数组名实际上就是第一个元素的地址,是一个常量。 (3)方括号中常量表达式表示数组元素的个数,可以是符号常量。因为数组和一般变量的空间在编译阶段分配,而变量的值在运行时才获得,编译时并不知道变量的值,因此不能用变量定义数组的大小。 (4)数组占用空间大小的计算,可以用sizeof运算符。数组总字节数=sizeof(类型说明符)*数组长度=sizeof(数组名)。 9.2.2 一维数组引用 数组元素的的标识方法为数组名后跟下标。引用数组元素的一般形式为:数组名[下标]。下标只能为整型常量、整型变量、整型表达式。 每个数组元素和变量一样,可以进行读写、输入输出操作等。 数组定义的方括号中给出的是数组长度,只能是常量。数组元素引用中的下标是元素在数组中位置的标识,可以是整型常量、整型变量、整型表达式。 注意: (1)使用具有N个元素的数组时,引用下标为0~N-1,第一个元素为数组名[0],最后一个元素为数组名[N-1]。数组名代表起始地址,下标代表从起始地址开始偏移几个元素,第一个元素偏移0,第N个元素偏移N-1,下标为N-1。 (2)引用数组元素下标越界时,运行并不报错(因为检查是否越界占用系统时间,C语言崇尚高效),但越界使用可能破坏其他数据。 (3)C语言中只能单个的使用下标标识每个数组元素。 用循环语句输入、输出数组元素的值: int iArr[5]; for(i=0;i<5;i++) scanf("%d",&iArr;); for(i=0;i<5;i++) printf("%d",iArr[i]); 对元素分别赋值1,2,3,4,5 int iArr[5]; for(i=0;i<5;i++) iArr[i]=i+1; (4)数组定义后若不给元素赋值,则值由编译器指定无意义的数据。 9.2.3 一维数组初始化 给数组赋值有两种方法:赋值语句对数组元素逐个赋值,初始化赋值。初始化赋值指在数组定义时给数组元素赋予初值。 数组初始化是在编译阶段进行的,可以减少运行时间,提高效率。 初始化赋值的形式: 类型说明符 数组名[常量表达式]={值1,值2,···,值n}; 对数组初始化赋值的说明: (1)可以只给部分元素赋初值,当{}中值的个数少于元素个数时,只给前面部分元素赋初值,未赋值的元素会赋予与数组元素类型相关的特定值,整型为0,浮点型为0.0,字符型为'\0'。 补充说明:字符'0'和'\0'区别: 字符'0':ASCII码为48,内存中存放表示:00110000。 字符'\0' :ASCII码为0,表示一个字符串结束的标志。这是转义字符(整体视为一个字符)。由于内存中存储字符,存储的是对应字符集的字符编码,所以内存中的表现形式为00000000。 (2)只能给元素逐个赋值。如给5个元素全部赋初值1,要写成: int iA[5]={1,1,1,1,1}; (3)如果给元素全部赋值,可以不给出数组长度(即数组元素的个数)。 9.2.4 一维数组案例分析 例:把一个整数插入到已经按照从小到大顺序排好序的整型数组中,使得整型数组依然有序。 【问题分析】

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值