码迷,mamicode.com
首页 > 其他好文 > 详细

STl具体操作之优先队列

时间:2015-07-29 12:19:46      阅读:92      评论:0      收藏:0      [点我收藏+]

标签:


优先队列  queue
/*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;
 }*/

版权声明:本文为博主原创文章,未经博主允许不得转载。

STl具体操作之优先队列

标签:

原文地址:http://blog.csdn.net/yueloveme/article/details/47124107

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!