Map和Set

2020-05-27  本文已影响0人  monkeyfly36

[图片上传中...(image.png-24fde2-1590629267229-0)]

Map本质上是键值对的集合(Hash 结构)。
原因:传统对象只能用字符串当作键,这给它的使用带来了很大的限制。ES6 Map“键”的范围不限于字符串,各种类型的值(包括对象)都可以当作键。
也就是说,Object 结构提供了“字符串—值”的对应,Map 结构提供了“值—值”的对应,是一种更完善的 Hash 结构实现。

Map实例的属性和操作方法(6):
size:返回成员总数
set(key, value):添加新的键值
get(key):读取键对应的值
has(key):是否有某个键
delete(key):删除某个键
clear():清空

Map实例的遍历方法(4):
keys():返回键名的遍历器。
values():返回键值的遍历器。
entries():返回键值对的遍历器。
forEach()/for(let [key, value] of newMap):遍历 Map 的所有成员

初始化--两种

1.var hashMap = new Map()
hashMap.set('a',1)
hashMap.set('b',2)

2.var hashMap = new Map([
['a',1],['b',2]
])

应用
数组去重
找到数组中重复的数
找到数组中第一个非重复的数

// 数组去重
function arrayNonRepeatfy(arr) {
  let hashMap = new Map()
  let result = []  // 数组用于返回结果
  for (let i = 0; i < arr.length; i++) {
    if(hashMap.has(arr[i])) { // 判断 hashMap 中是否已有该 key 值
      hashMap.set(arr[i], true) // 后面的true 代表该 key 值在原始数组中重复了,false反之
    } else {  // 如果 hashMap 中没有该 key 值,添加
      hashMap.set(arr[i], false)
      result.push(arr[i]);
    }
  } 
  return result 
}
// 找到数组中重复的数
function findRepeatNumInArray(arr) {
  let hashMap = new Map()
  let result = new Array()
  for (let i = 0; i < arr.length; i++) {
    hashMap.set(arr[i], hashMap.has(arr[i]))
  }
  // 得到 hashMap 后,对其进行遍历,值为 true,对应的键就是重复的数
  for(let [key, value] of hashMap.entries()) { 
    if(value === true) {
      result.push(key)
    }
  }
  return result
}
// 找到数组中第一个非重复的数
function findFirstNonRepeat(arr) {
  let hashMap = new Map()
  for (let i = 0; i < arr.length; i++) {
    hashMap.set(arr[i], hashMap.has(arr[i]))
  }
  // 找到第一个值为 false 的,就代表第一个非重复数,return 就好了
  for(let [key, value] of hashMap.entries()) {
    if(value === false) {
      return key
    }
  }
  return "全部重复"
}
上一篇下一篇

猜你喜欢

热点阅读