data:image/s3,"s3://crabby-images/feb11/feb116e6e538ba6bc6ef0c8a5d442f481416a8a2" alt=""
The key intuition is to maintain two vectors such that dense[sparse[k]] = k, and a variable which maintains the number of elements in the sparse set. sparse[k] contains the number of elements in the set, when element k is inserted. In this way two elements inserted consecutively are mapped into contiguous positions of the dense vector. As a consequence, insert and delete operations are constant, while intersection and union operations are sub-linear.
This is the code for Sparse Sets representation in C++.
No comments:
Post a Comment