您的位置:首页 > 其它

STL具体操作之set

2015-07-29 11:01 253 查看

set 具体操作 之前打错了 不好意思

/*begin()    ,返回set容器的第一个元素

end()      ,返回set容器的最后一个元素

clear()    ,删除set容器中的所有的元素

empty()    ,判断set容器是否为空

max_size()   ,返回set容器可能包含的元素最大个数

size()      ,返回当前set容器中的元素个数

rbegin     ,返回的值和end()相同

rend()     ,返回的值和rbegin()相同

#include <iostream>

#include <set>

using namespace std;

int main()

{

set<int> s;

s.insert(1);

s.insert(2);

s.insert(3);

s.insert(1);

printf("set 的 size 值为 :%d",s.size());

printf("set 的 maxsize的值为 :%d",s.max_size());

printf("set 中的第一个元素是 :%d",*s.begin());

cout<<"set 中的最后一个元素是:"<<*s.end()<<endl;

s.clear();

if(s.empty())

{

cout<<"set 为空 !!!"<<endl;

}

cout<<"set 的 size 值为 :"<<s.size()<<endl;

cout<<"set 的 maxsize的值为 :"<<s.max_size()<<endl;

return 0;

}

count() 用来查找set中某个某个键值出现的次数。这个函数在set并不是很实用,因为一个键值在set只可能出现0或1次,这样就变成了判断某一键值是否在set出现过了。

#include <iostream>

#include <set>

using namespace std;

int main()

{

set<int> s;

s.insert(1);

s.insert(2);

s.insert(3);

s.insert(1);

printf("set 中 1 出现的次数是 :%d\n",s.count(1));

cout<<"set 中 4 出现的次数是 :"<<s.count(4)<<endl;

return 0;

}

equal_range() ,返回一对定位器,分别表示第一个大于或等于给定关键值的元素和 第一个大于给定关键值的元素,这个返回值是一个pair类型,如果这一对定位器中哪个返回失败,就会等于end()的值。

#include <iostream>

#include <set>

#include<stdio.h>

using namespace std;

int main()

{

set<int> s;

set<int>::iterator iter;

for(int i = 1 ; i <= 5; ++i)

{

s.insert(i);

}

for(iter = s.begin() ; iter != s.end() ; ++iter)

{

cout<<*iter<<" ";

}

cout<<endl;

pair<set<int>::const_iterator,set<int>::const_iterator> pr;

pr = s.equal_range(3);

cout<<"第一个大于等于 3 的数是 :"<<*pr.first<<endl;

cout<<"第一个大于 3的数是 : "<<*pr.second<<endl;

return 0;

}

erase(iterator) ,删除定位器iterator指向的值

erase(first,second),删除定位器first和second之间的值

erase(key_value),删除键值key_value的值

#include <iostream>

#include <set>

using namespace std;



int main()

{

set<int> s;

set<int>::const_iterator iter;

set<int>::iterator first;

set<int>::iterator second;

for(int i = 1 ; i <= 10 ; ++i)

{

s.insert(i);

}

//第一种删除

s.erase(s.begin());

//第二种删除

first = s.begin();

second = s.begin();

second++;

second++;

s.erase(first,second);

//第三种删除

s.erase(8);

cout<<"删除后 set 中元素是 :";

for(iter = s.begin() ; iter != s.end() ; ++iter)

{

cout<<*iter<<" ";

}

cout<<endl;

return 0;

}

insert(key_value); 将key_value插入到set中 ,返回值是pair<set<int>::iterator,bool>,bool标志着插入是否成功,而iterator代表插入的位置,若key_value已经在set中,则iterator表示的key_value在set中的位置。

inset(first,second);将定位器first到second之间的元素插入到set中,返回值是void.

#include <iostream>

#include <set>

using namespace std;

int main()

{

int a[] = {1,2,3};

set<int> s;

set<int>::iterator iter;

s.insert(a,a+3);

for(iter = s.begin() ; iter != s.end() ; ++iter)

{

cout<<*iter<<" ";

}

cout<<endl;

pair<set<int>::iterator,bool> pr;

pr = s.insert(5);

if(pr.second)

{

cout<<*pr.first<<endl;

}

return 0;

}

lower_bound(key_value) ,返回第一个大于等于key_value的定位器

upper_bound(key_value),返回最后一个大于等于key_value的定位器

#include <iostream>

#include <set>

using namespace std;

int main()

{

set<int> s;

s.insert(1);

s.insert(3);

s.insert(4);

cout<<*s.lower_bound(2)<<endl;

cout<<*s.lower_bound(3)<<endl;

cout<<*s.upper_bound(3)<<endl;

return 0;

}*/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: