Set是一种关联容器,存储有序且唯一的键值;其大多用法和vector相同就不多加解释,只阐述它的特殊性;我个人认为Set容器的局限性还是比较大的,仅认为Set可以在排序和清除不必要元素时使用,因为Set遍历的时候只可以用迭代器,而且在删除元素时不方便。(删除键值除外);
1.头文件<set>;
2.添加元素——a.insret();
3.清除键值元素——a.erase(m); m表示你要清除的元素值,而不是元素的位置;
4.元素的遍历方向
前向遍历
set<int> a; for(set<int> :: iterator oss = a.begin();oss != a.end();oss++) { cout << *oss << " "; }
后序遍历
for(set<int> :: reverse_iterator oss = a.rbegin();oss != a.rend();oss++) { cout << *oss << " "; }
5.元素的逆序排列;(简单的——可添加)
重载“()”操作符;
struct Comp { bool operator()(const int&x ,const int&y)//重写操作符operator(); { if(x!=y) return x>y; else return x>y; } }; int main() { set<int,Comp> a; a.insert(1); a.insert(2); a.insert(3); for(set<int,Comp> :: iterator oss = a.begin();oss != a.end();oss++) { cout << *oss << " "; } cout << endl; return 0; }