zoukankan      html  css  js  c++  java
  • 【STL__set_的应用】

    1.关于set

    C++ STL 之所以得到广泛的赞誉,也被很多人使用,不只是提供了像vector, string, list等方便的容器,

    更重要的是STL封装了许多复杂的数据结构算法和大量常用数据结构操作。vector封装数组,list封装了链表,

    map和set封装了二叉树等,在封装这些数据结构的时候,STL按照程序员的使用习惯,

    以成员函数方式提供的常用操作,如:插入、排序、删除、查找等。让用户在STL使用过程中,并不会感到陌生。

    关于set,必须说明的是set关联式容器。set作为一个容器也是用来存储同一数据类型的数据类型,

    并且能从一个数据集合中取出数据,在set中每个元素的值都唯一,而且系统能根据元素的值自动进行排序。

    应该注意的是set中数元素的值不能直接被改变。C++ STL中标准关联容器set, multiset, map, multimap内部

    采用的就是一种非常高效的平衡检索二叉树:红黑树,也成为RB树(Red-Black Tree)。RB树的统计性能要好

    于一般平衡二叉树,所以被STL选择作为了关联容器的内部结构。

    2.set中常用的方法


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

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

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

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

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

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

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

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

     


    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);
        cout<<"set 中 1 出现的次数是 :"<<s.count(1)<<endl;
        cout<<"set 中 4 出现的次数是 :"<<s.count(4)<<endl;
        return 0;
    }
    

      


    equal_range() ,返回一对定位器,分别表示第一个大于或等于给定关键值的元素和 第一个大于给定关键值的元素,这个返回值是一个pair类型,如果这一对定位器中哪个返回失败,就会等于end()的值。具体这个有什么用途我还没遇到过~~~

    示例代码:

    #include <iostream>
    #include <set>
    
    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;
    }
    

      


    find()  ,返回给定值值得定位器,如果没找到则返回end()。

    示例代码:

    #include <iostream>
    #include <set>
    
    using namespace std;
    
    int main()
    {
        int a[] = {1,2,3};
        set<int> s(a,a+3);
        set<int>::iterator iter;
        if((iter = s.find(2)) != s.end())
        {
            cout<<*iter<<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;
    }
    

      

  • 相关阅读:
    URL参数加密专用
    错误
    js学习类
    .net第一个服务器控件
    javascript中的call()和apply()方法 原创实例
    FIS使用技巧
    自定义参数表单URL参数处理
    避免编写解决"不存在"问题的代码
    从 1.1.0 升级到 1.2.0 的注意事项
    jquery常用插件,应用解析
  • 原文地址:https://www.cnblogs.com/wushuaiyi/p/4432281.html
Copyright © 2011-2022 走看看