I\'m working in JavaScript. I\'d like to store a list of unique, unordered string values, with the following properties:
I just noticed that d3.js library has implementation of sets, maps and other data structures. I can't argue about their efficiency but judging by the fact that it is a popular library it must be what you need.
The documentation is here
For convenience I copy from the link (the first 3 functions are those of interest)
Constructs a new set. If array is specified, adds the given array of string values to the returned set.
Returns true if and only if this set has an entry for the specified value string.
Adds the specified value string to this set.
If the set contains the specified value string, removes it and returns true. Otherwise, this method does nothing and returns false.
Returns an array of the string values in this set. The order of the returned values is arbitrary. Can be used as a convenient way of computing the unique values for a set of strings. For example:
d3.set(["foo", "bar", "foo", "baz"]).values(); // "foo", "bar", "baz"
Calls the specified function for each value in this set, passing the value as an argument. The this context of the function is this set. Returns undefined. The iteration order is arbitrary.
Returns true if and only if this set has zero values.
Returns the number of values in this set.