开发者

Which STL container to use if I want it to ignore duplicated elements?

开发者 https://www.devze.com 2022-12-13 21:27 出处:网络
I am looking for some STL (but not boost) container, which开发者_运维百科 after the following operations will contain 2 elements: \"abc\" and \"xyz\":

I am looking for some STL (but not boost) container, which开发者_运维百科 after the following operations will contain 2 elements: "abc" and "xyz":

std::XContainer<string> string_XContainer;
string_XContainer.push_back("abc");
string_XContainer.push_back("abc");
string_XContainer.push_back("xyz");

By the way, I need it just in order to call string_XContainer.size() in the end, to get the total number of unique strings. So maybe I don't even need a container, and there is a more elegant way of doing it?


std::set is the one you are after. A set will contain at most one instance of each element, compared according to some comparator function you define.

This would be one approach to get the number of unique strings. From your example, the strings were already in sorted order? If that's the case, then you could just create an array (or some other simple structure) and use the std::unique algorithm.

0

精彩评论

暂无评论...
验证码 换一张
取 消