www.digitalmars.com         C & C++   DMDScript  

digitalmars.D.learn - Ordered set container?

reply Victor Porton <porton narod.ru> writes:
I want "ordered set" container (like list or vector but with the 
warranty of no duplicate elements).

Which type can I use?
Jan 28 2019
next sibling parent Neia Neutuladh <neia ikeran.org> writes:
On Mon, 28 Jan 2019 17:18:52 +0000, Victor Porton wrote:
 I want "ordered set" container (like list or vector but with the
 warranty of no duplicate elements).
 
 Which type can I use?
std.container.rbtree It has options to preserve or squash duplicates.
Jan 28 2019
prev sibling next sibling parent "H. S. Teoh" <hsteoh quickfur.ath.cx> writes:
On Mon, Jan 28, 2019 at 05:18:52PM +0000, Victor Porton via Digitalmars-d-learn
wrote:
 I want "ordered set" container (like list or vector but with the
 warranty of no duplicate elements).
 
 Which type can I use?
Try std.container.rbtree.RedBlackTree. T -- That's not a bug; that's a feature!
Jan 28 2019
prev sibling parent Dukc <ajieskola gmail.com> writes:
On Monday, 28 January 2019 at 17:18:52 UTC, Victor Porton wrote:
 I want "ordered set" container (like list or vector but with 
 the warranty of no duplicate elements).
The above answers are ordered, but if you want a type that's a simple sorted array, there's none at the standard library besides SortedRange, which you can't add to. (Mostly for a good reason, because adding elements to such an array after the initial sorting would be very slow). https://github.com/nordlow/justd/blob/master/stdx/container/sorted.d contains an implementation of such an array, but one cannot currently use it legally, because it is not licensed. I don't know if the author did that intentionally (Nordlöw, are you around?)
Jan 29 2019