zoukankan      html  css  js  c++  java
  • std::Set

    set集合容器实现了红黑树(Red-Black Tree)的平衡二叉检索树的的数据结构,

    在插入元素时,它会自动调整二叉树的排列,把该元素放到适当的位置,以确保每个子树根节点的键值大于左子树所有节点的键值,而小于右子树所有节点的键值;

    另外,还得确保根节点的左子树的高度与有字数的高度相等,

    这样,二叉树的高度最小,从而检索速度最快。

    它不会重复插入相同键值的元素,而采取忽略处理。
    平衡二叉检索树的检索使用中序遍历算法,
    检索效率高于vector、deque、和list的容器。
    平衡二叉检索树在插入元素时,就会自动将元素按键值从小到大的顺序排列。
    set<int>::iterator it;             // 定义前向迭代器  
    set<int>::reverse_iterator rit;    // 定义反向迭代器
    it = s.erase(it++);                // 删除
    it = s.find(6);                    // 查找的元素  
    s.count(a)                         // 是否在集合中

    如果元素不是结构体,那么可以编写比较函数。下面的程序比较规则为按键值从大到小的顺序插入到集合中。

    #include<iostream>  
     #include<set>  
     using namespace std;  
     struct mycomp  
     { //自定义比较函数,重载“()”操作符  
          bool operator() (const int &a, const int &b)  
          {  
              if(a != b)  
                  return a > b;  
             else  
                 return a > b;  
         }  
     };  
     int main()  
     {  
         set<int, mycomp> s; //采用比较函数mycomp  
         s.insert(5); //第一次插入5,可以插入  
         s.insert(1);  
         s.insert(6);  
         s.insert(3);  
         s.insert(5); //第二次插入5,重复元素,不会插入  
         set<int,mycomp>::iterator it;  
         for(it = s.begin(); it != s.end(); it++)  
             cout << *it << " ";  
         cout << endl;  
         return 0;  
     }  

    如果元素是结构体,那么可以直接把比较函数写在结构体内。

    #include<iostream>  
    #include<set>  
    #include<string>  
    using namespace std;  
    struct Info  
    {  
         string name;  
         double score;  
         bool operator < (const Info &a) const // 重载“<”操作符,自定义排序规则  
         {  
             //按score由大到小排序。如果要由小到大排序,使用“>”即可。  
             return a.score < score;  
         }  
     };  
     int main()  
     {  
         set<Info> s;  
         Info info;  
       
         //插入三个元素  
         info.name = "Jack";  
         info.score = 80;  
         s.insert(info);  
     
         info.name = "Tom";  
         info.score = 99;  
         s.insert(info);  
     
         info.name = "Steaven";  
         info.score = 60;  
         s.insert(info);  
       
       set<Info>::iterator it;  
         for(it = s.begin(); it != s.end(); it++)  
             cout << (*it).name << " : " << (*it).score << endl;   
         return 0;  
     }  
     /* 
     运行结果: 
     Tom : 99 
     Jack : 80 
     Steaven : 60 
     */  
  • 相关阅读:
    laydate日期插件弹出闪退和多次闪退问题解决
    IconFont 图标的3种引用方式
    jquery操作select下拉框的多种方法(选中,取值,赋值等)
    jquery获取select选中项 自定义属性的值
    Centos查看端口占用、开启端口
    IaaS,PaaS,SaaS 的区别
    IOS手机使用Fiddler抓包(HTTPS)(二)
    Android手机使用Fiddler抓包(HTTPS)(二)
    Fiddler使用详解(一)
    python2.x和python3.x中raw_input( )和input( )区别
  • 原文地址:https://www.cnblogs.com/osbreak/p/9206470.html
Copyright © 2011-2022 走看看