1 set
What is a set
A set is usually made up of an unordered set of elements that cannot be repeated. A set can be thought of as a special kind of array, special in that its elements are not sequential and cannot be repeated.
- No order means no access through subscript values.
- Non-repetition means that there will only be one copy of the same object in the collection.
Encapsulation of collections
It is divided into two parts. The first part is the operation of adding, deleting, modifying and checking sets. The second part is the operation of intersection and union between sets. Because they are relatively simple, they are packaged together.
class Set { constructor() { this.items = {}; } // has(value) : returns true if the value is in the collection, false otherwise. has(value) { return this.items.hasOwnProperty(value); } // add(value) : Adds a new item to the collection. add(value) { if (this.has(value)) { return false; } this.items[value] = value; return true; } // remove(value) : Removes a value from the collection. remove(value) { if (! this.has(value)) { return false; } delete this.items[value]; } // clear() : removes all items in the collection. clear() { this.items = {}; } // size() : Returns the number of elements contained in the collection. Similar to the length property of an array. size() { return Object.keys(this.items).length; } // values() : Returns an array containing all the values in the collection. values() { return Object.keys(this.items); } / / -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- / / the union and Set the union (otherSet) {let unionSet = new Set (); let values = this.values(); for (let i = 0; i < values.length; i++) { unionSet.add(values[i]); } values = otherSet.values(); for (let i = 0; i < values.length; i++) { unionSet.add(values[i]); } return unionSet; } // intersection intersection intersection(otherSet) {let intersectionSet = new Set(); let values = this.values(); for (let i = 0; i < values.length; i++) { let item = values[i]; if (otherSet.has(item)) { intersectionSet.add(item); } } return intersectionSet; } // Different differentSet different(otherSet) {let differentSet = new Set(); let values = this.values(); for (let i = 0; i < values.length; i++) { let item = values[i]; if (! otherSet.has(item)) { differentSet.add(item); } } return differentSet; } subset subset subset(otherSet) {let subsetSet = new Set(); let values = this.values(); for (let i = 0; i < values.length; i++) { let item = values[i]; if (! this.has(item)) { return false; } } return true; } // let setA = new Set(); setA.add('aaa'); setA.add('bbb'); setA.add('ccc'); // console.log(setA); // console.log(setA.has('aaa')); // console.log(setA.size()); // console.log(setA.values()); // setA.remove('aaa'); // console.log(setA); // setA.clear(); // console.log(setA); //------------------- let setB = new Set(); setB.add('aaa'); setB.add('abc'); setB.add('ddd'); let setC = new Set(); setC.add('aaa'); console.log(setA.union(setB)); console.log(setA.intersection(setB)); console.log(setA.different(setB)); console.log(setA.subset(setC));Copy the code
2 the dictionary
- In JavaScript, it seems like objects themselves are dictionaries, so in the early days of JavaScript, there was no such thing as a dictionary, because you could just use objects as dictionaries
- ES6 added maps (dictionaries)