Small knowledge, big challenge! This article is participating in the creation activity of “Essential Tips for Programmers”.
preface
Q1: What are Map and Set?
Prior to ES6, implementing “key/value” storage in JavaScript could be done easily and efficiently using Object, that is, using Object properties as keys and properties to reference values, as shown below
let student = {
name: 'ah blare'.sex: 'male'.age: 18
}
Copy the code
This implementation is not without its problems, however, where the keys can only be attributes of the object. This is where the new collection type Map comes in, which brings true key/value storage to JavaScript. We can initialize mappings like this:
const map = new Map([['key1'.'value1'],
['key2'.'value2'],
['key3'.'value3']])Copy the code
ES6 also adds a new collection type, Set, which in many ways looks like enhanced Maps because most of their apis and behaviors are common. The Set collection type is characterized by the fact that it cannot store duplicate elements. The values of the members are unique and have no duplicate values
How to use the basic API of Map and Set?
The Map API:
-
Get () : Returns a key-value pair
-
Set () : Adds a key-value pair and returns an instance
-
Delete () : Deletes the key-value pair and returns a Boolean
-
Has () : Checks the key-value pair and returns a Boolean
-
Clear () : Clears all members
-
Keys () : Returns the object with the key as traverser
-
Values () : Returns an object with a value as a traverser
-
Entries () : Returns an object with keys and values as traversers
-
ForEach () : Iterates through each member using the callback function
The Set of API:
-
Add () : Adds the value and returns the instance
-
Delete () : Deletes the value and returns a Boolean
-
Has () : Checks the value and returns a Boolean
-
Clear () : Clears all members
-
Keys () : Returns an object with the property value as a traverser
-
Values () : Returns the object with the attribute value as the traverser
-
Entries () : Returns objects with property values and property values as traversers
-
ForEach () : Iterates through each member using the callback function
Now that you’re familiar with JS maps and sets, let’s try using these two collection types in LeetCode
LeetCode20: Valid parentheses
Given a only include a ‘(‘,’) ‘, ‘{‘,’} ‘, ‘/’, ‘ ‘the string s, determine whether a string is effective.
Example 1:
Input: s = “()” output: true
Example 2:
Input: s = “()[]{}” Output: true
Example 3:
Input: s = “(]” Output: false
Stack +Map = Map + stack +Map = Map + stack +Map
LeetCode141: Circular linked list
Given a linked list, determine whether there are rings in the list.
Example:
Input: head = [3,2,0,-4], pos = 1 output: true
This problem I thought is to use the Set to solve, of course, there is another method, using the fast pointer to solve, but more difficult to think of, and more anti-human, we only introduce the Set, clear and easy to understand ~
The last
โฝ this article mainly introduces the Map and Set in part of the algorithm problem in the clever use ~, I believe you should have some harvest, will be updated more algorithms related articles, So pay attention to a wave of ah ~ โพ if you are interested in this article welcome to praise attention + collection, more wonderful knowledge is waiting for you! ๐ ๐GitHub blogs at github.com/Awu1227. ๐ I have other columns, please read ~ ๐ play the beauty of CSS ๐ฑVue from giving up to getting started ๐ณ simple JavaScript