I’m looking for an easy (and quick) way to determine if two unordered lists contain the same elements:
For example:
['one', 'two', 'three'] == ['one', 'two', 'three'] : true
['one', 'two', 'three'] == ['one', 'three', 'two'] : true
['one', 'two', 'three'] == ['one', 'two', 'three', 'three'] : false
['one', 'two', 'three'] == ['one', 'two', 'three', 'four'] : false
['one', 'two', 'three'] == ['one', 'two', 'four'] : false
['one', 'two', 'three'] == ['one'] : false
I’m hoping to do this without using a map.
Python has a built-in datatype for an unordered collection of (hashable) things, called a
set. If you convert both lists to sets, the comparison will be unordered.Documentation on
setEDIT: @mdwhatcott points out that you want to check for duplicates.
setignores these, so you need a similar data structure that also keeps track of the number of items in each list. This is called a multiset; the best approximation in the standard library is acollections.Counter: