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