Python - Sets .pop() Behaviour
This is the strange thing I noticed in Python sets. I read there is no order in sets, but it does pop lower elements from 0 till 79 and later from 79 till 127. It does not pop the
Solution 1:
There is a "consistent" internal ordering depending on the insertion and removal of elements in dictionaries. See: http://docs.python.org/library/stdtypes.html#dict.items
As far as I'm aware sets use the same hashing implementation and will most likely have the same ordering effects.
Solution 2:
Why is it popping the lowest from 0 till 79 and not from 79 to 128 ?
Well no , the ordering is not random but it's completely arbitrary. There's is no specific ordering in python sets. Consider this :
>>> s.add(14)
>>> s.add(11)
>>> s.add(3)
>>> s.add(13)
>>> s.add(2)
>>> s.pop()
13
>>> s.pop()
14
>>> s.pop()
2
>>> s.pop()
3
>>> s.pop()
11
This isn't complying to your conclusion.( this time it happens for 14 )
Post a Comment for "Python - Sets .pop() Behaviour"