C++之set/multise容器
set基本概念
 
set构造和赋值

#include <iostream>
#include<set>
using namespace std;
void PrintfSet(set<int>&s)
{
    for(set<int>::iterator it = s.begin();it != s.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
void test()
{
    set<int> s1;
    //插入数据,只有insert方式
    s1.insert(10);
    s1.insert(40);
    s1.insert(20);
    s1.insert(40);
    s1.insert(30);
    //set容器特点: 所有元素插入时候自动被排序
    //set容器不允许插入重复值
    PrintfSet(s1);
    //拷贝构造
    set<int>s2(s1);
    PrintfSet(s2);
    //赋值操作
    set<int>s3;
    s3 = s1;
    PrintfSet(s3);
}
int main()
{
    test();
    cout << "Hello World!" << endl;
    return 0;
}
 

set大小和交换

#include <iostream>
#include<set>
using namespace std;
void PrintfSet(set<int>&s)
{
    for(set<int>::iterator it = s.begin();it != s.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
void test()
{
    set<int> s1;
    //插入数据,只有insert方式
    s1.insert(10);
    s1.insert(40);
    s1.insert(20);
    s1.insert(40);
    s1.insert(30);
    //set容器特点: 所有元素插入时候自动被排序
    //set容器不允许插入重复值
    PrintfSet(s1);
    if(s1.empty())
    {
        cout<<"s1 is empty"<<endl;
    }
    else
    {
        cout<<"s1 is not empty"<<endl;
        cout<<"s1's size is "<<s1.size()<<endl;
    }
    set<int>s2;
    s2.insert(100);
    s2.insert(200);
    s2.insert(300);
    s2.insert(400);
    //swap
    cout<<"before swap"<<endl;
    PrintfSet(s1);
    PrintfSet(s2);
    s2.swap(s1);
    cout<<"after swap"<<endl;
    PrintfSet(s1);
    PrintfSet(s2);
}
int main()
{
    test();
    cout << "Hello World!" << endl;
    return 0;
}
 

set插入和删除

#include <iostream>
#include<set>
using namespace std;
void PrintfSet(set<int>&s)
{
    for(set<int>::iterator it = s.begin();it != s.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
void test()
{
    set<int> s1;
    //插入数据,只有insert方式
    s1.insert(10);
    s1.insert(40);
    s1.insert(20);
    s1.insert(40);
    s1.insert(30);
    //set容器特点: 所有元素插入时候自动被排序
    //set容器不允许插入重复值
    PrintfSet(s1);
    s1.erase(s1.begin());
    PrintfSet(s1);
    s1.erase(30);
    PrintfSet(s1);
    //s1.erase(s1.begin(),s1.end());
    s1.clear();
}
int main()
{
    test();
    cout << "Hello World!" << endl;
    return 0;
}
 

set查找和统计

#include <iostream>
#include<set>
using namespace std;
void PrintfSet(set<int>&s)
{
    for(set<int>::iterator it = s.begin();it != s.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
void test()
{
    set<int> s1;
    //插入数据,只有insert方式
    s1.insert(10);
    s1.insert(40);
    s1.insert(20);
    s1.insert(40);
    s1.insert(30);
    //set容器特点: 所有元素插入时候自动被排序
    //set容器不允许插入重复值
    PrintfSet(s1);
    set<int>::iterator pos = s1.find(30);
    if(pos != s1.end())
    {
        cout<<"have finded"<<endl;
    }
    else
    {
        cout<<"no find"<<endl;
    }
//对于set而言 统计结果 要么是0 要么是1
    int num = s1.count(30);
    cout<<"num is "<<num<<endl;
}
int main()
{
    test();
    cout << "Hello World!" << endl;
    return 0;
}
 

set与multise区别

#include <iostream>
#include<set>
using namespace std;
void PrintfSet(set<int>&s)
{
    for(set<int>::iterator it = s.begin();it != s.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
void test()
{
    set<int> s1;
    //插入数据,只有insert方式
    pair<set<int>::iterator,bool> ret = s1.insert(10);
    if(ret.second)
    {
        cout<<"insert success at first"<<endl;
    }
    else
    {
        cout<<"insert fail at first"<<endl;
    }
    ret = s1.insert(10);
    if(ret.second)
    {
        cout<<"insert success at second"<<endl;
    }
    else
    {
        cout<<"insert fail at second"<<endl;
    }
    multiset<int>m1;
    //允许插入重复值
    m1.insert(10);
    m1.insert(10);
    m1.insert(10);
    m1.insert(10);
    for(multiset<int>::iterator it = m1.begin();it != m1.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
int main()
{
    test();
    cout << "Hello World!" << endl;
    return 0;
}
 

pair对组的创建

#include <iostream>
#include<set>
using namespace std;
void PrintfSet(set<int>&s)
{
    for(set<int>::iterator it = s.begin();it != s.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
void test()
{
    //第一种方式
    pair<string,int>p("Tom",20);
    cout<<"name is "<<p.first<<"age is "<<p.second<<endl;
    //第二种方式
    pair<string,int>p2 = make_pair("Jin",21);
    cout<<"name is "<<p2.first<<"age is "<<p2.second<<endl;
}
int main()
{
    test();
    cout << "Hello World!" << endl;
    return 0;
}
 

set排序

#include <iostream>
#include<set>
using namespace std;
void PrintfSet(set<int>&s)
{
    for(set<int>::iterator it = s.begin();it != s.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
class MyCompare
{
public:
    bool operator()(int v1,int v2)
    {
        return v1>v2;
    }
};
void test()
{
    set<int>s1;
    s1.insert(10);
    s1.insert(40);
    s1.insert(30);
    s1.insert(50);
    s1.insert(20);
    PrintfSet(s1);
    //指定排序规则为从大到小
    set<int,MyCompare>s2;
    s2.insert(10);
    s2.insert(40);
    s2.insert(30);
    s2.insert(50);
    s2.insert(20);
    for(set<int,MyCompare>::iterator it = s2.begin();it != s2.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
int main()
{
    test();
    cout << "Hello World!" << endl;
    return 0;
}
 

set存放自定义数据
#include<iostream>
#include<string>
using namespace std;
#include<set>
//set容器排序,存放自定义数据类型
class Person
{
public:
	Person(string name,int age)
	{
		this->m_name = name;
		this->m_age = age;
	}
	string m_name;
	int m_age;
};
class MyCompare
{
public:
	bool operator()(const Person&p1, const Person& p2)
	{
		//按照年龄进行降序
		return p1.m_age > p2.m_age;
	}
};
void test()
{
	//指定排序规则为从大到小
	set<Person, MyCompare>s;
	//创建Person对象
	Person p1 ("liubei",23);
	Person p2("zhangfei", 21);
	Person p3("guanyu", 22);
	Person p4("zhaoyun", 24);
	s.insert(p1);
	s.insert(p2);
	s.insert(p3);
	s.insert(p4);
	for (set<Person, MyCompare>::iterator it = s.begin();it != s.end();it++)
	{
		cout << "name is " << (*it).m_name << "age is " << (*it).m_age << endl;
	}
	cout << endl;
}
int main()
{
	test();
	system("pause");
	return 0;
}
 



















