STL详解之set和multiset

set:里面的元素不能重复,自动排序

multiset:里面的元素自动排序,可以有重复的。

#include <iostream>
using namespace std;
#include <set>
#include <vector>
void f1()
{
int ia[10] = { 2, 1, 3, 5, 8, 5, 3, 1, 5, 8 };  //不取最后一位的反斜杠0
vector<int> vec(ia, ia + 10);


set<int> iset(vec.begin(), vec.end());


set<int>::iterator it;  //迭代器遍历的方式
for (it = iset.begin(); it != iset.end(); it++)
cout << *it << endl;


cout<<"--------------------------"<<endl;
//向set中加入元素,insert
iset.insert(4);
for (it = iset.begin(); it != iset.end(); it++)
cout << *it << endl;
}


void f2()
{
/**
* 1.创建对象时,不能指定长度
* 2.不能有重复元素
* 3.元素顺只与值有关
*/
set<int> iset;
iset.insert(2);
iset.insert(8);
iset.insert(2);
iset.insert(5);
set<int>::iterator it;
for (it = iset.begin(); it != iset.end(); it++)
{
cout << *it << endl;
}
}
/**
 * multiset:可以有重复的元素
 */
void f3()
{
int ia[10] = { 1, 1, 3, 5, 8, 5, 3, 1, 5, 8 };
vector<int> vec(ia, ia + 10);


multiset<int> iset(vec.begin(), vec.end());
multiset<int>::iterator index;
for (index = iset.begin(); index != iset.end(); index++)
{
cout << *index << endl;
}
}
int main()
{
f3();
return 0;
}

阅读更多

没有更多推荐了,返回首页