16.8.1【set容器的基本概念、构造和赋值】

#include<iostream>
#include<cstdlib>
using namespace std;
#include<set>


/*
    3.8 set/multiset容器

    3.8.1 set基本概念

        简介:所有元素都会在插入时自动被排序

        本质:set/multiset属于关联式容器,底层结构是用二叉树实现。

        set和multiset区别:
            set不允许容器中有重复的元素
            multiset允许容器中有重复的元素

    3.8.2 set构造和赋值

        功能:创建set容器以及赋值

        构造:
            set<T> st; //默认构造函数:
            set(const set &st); //拷贝构造函数

        赋值:
            set& operator=(const set &st); //重载等号操作符
*/


print_set(const set<int> & s)
{
    for(set<int>::const_iterator cit=s.begin(); cit!=s.end(); cit++)
    {
        cout << *cit << " ";
    }
    cout << endl;
}


void test382()
{
    set<int> s1; //默认构造

    s1.insert(10); //注意set插入数据只有insert方法,没有push
    s1.insert(40);
    s1.insert(20);
    s1.insert(20);
    s1.insert(30);
    s1.insert(10);

    print_set(s1);
    //set容器特点:所有元素在插入时被自动排序;不允许插入重复值,即使插入了不报错也不会插入生效

    set<int> s2(s1); //拷贝构造
    print_set(s2);

    set<int> s3;
    s3 = s2; //赋值
    print_set(s3);
}


int main()
{
    test382();

    system("pause");
    return 0;
}

 

 

 

 

posted @ 2021-05-12 11:12  yub4by  阅读(106)  评论(0编辑  收藏  举报