set和map和pair 转自ACdreamers

set与map容器

分类:             C/C++              2013-08-25 19:21     560人阅读     评论(0)     收藏     举报

首先来看看set集合容器:

set集合容器实现了红黑树的平衡二叉树数据结构,在插入元素时它会自动调整二叉树的排列,把该元素放到适当的位置,并且保证左右子树平衡。平衡二叉检索树采用中序遍历算法。

对于set,vector,map等等,它们的前向迭代器定义是这样的(以set为例):

set<int>::iterator it;

for(it=s.begin();it!=s.end();it++){}

那么反向迭代器呢?

set<int>::reverse_iterator rit;

for(rit=s.rbegin();rit!=s.rend();rit++){}

常用方法:insert(),erase(),find(),clear()

find()方法是查找元素方法,如果找到就返回该元素迭代器的位置,否则就返回最后一个元素后面的一个位置。

这样来使用:

it=s.find(5);

if(it!=s.end()) {}

else            {}

关于比较函数:

如果元素不是结构体,而是基本数据类型,那么就自己定义一个比较函数:

[cpp] view plaincopyprint?

  1. struct cmp
  2. {
  3. bool operator()(const int &a,const int &b)
  4. {
  5. return a>b;
  6. }
  7. };
  8. int main()
  9. {
  10. set<int,cmp> s;
  11. for(int i=1;i<10;i++)
  12. s.insert(i);
  13. set<int,cmp>::iterator it;
  14. for(it=s.begin();it!=s.end();it++)
  15. cout<<*it<<" ";
  16. return 0;
  17. }
struct cmp
{
    bool operator()(const int &a,const int &b)
    {
        return a>b;
    }
};

int main()
{
    set<int,cmp> s;
    for(int i=1;i<10;i++)
       s.insert(i);
    set<int,cmp>::iterator it;
    for(it=s.begin();it!=s.end();it++)
        cout<<*it<<" ";
    return 0;
}

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

[cpp] view plaincopyprint?

  1. struct Student
  2. {
  3. string name;
  4. double score;
  5. bool operator < (const Student &a) const
  6. {
  7. return a.score<score;
  8. }
  9. };
  10. set<Student> s;
struct Student
{
    string name;
    double score;
    bool operator < (const Student &a) const
    {
        return a.score<score;
    }
};

set<Student> s;

对于set容器来说,它不能有关键字相同的元素同时存在,如果要保留相同的元素,就用multiset多重集合容器。

其基本操作跟set集合容器差不多一样。定义方法是:multiset<string> ms;

map映照容器:

map映照容器的元素数据是由一个键值和一个映照数据组成的,键值与映照数据之间具有一一对应关系。map也是用红黑树实现

的。同set一样,map不允许插入元素键值相同,而multimap多重应照集合可以允许键值重复。

使用方法:

[cpp] view plaincopyprint?

  1. int main()
  2. {
  3. map<string,double> m;
  4. m["Jack"]=98.0;
  5. map<string,double>::iterator it;
  6. for(it=m.begin();it!=m.end();it++)
  7. cout<<(*it).first<<" "<<(*it).second<<endl;
  8. return 0;
  9. }
int main()
{
    map<string,double> m;
    m["Jack"]=98.0;
    map<string,double>::iterator it;
    for(it=m.begin();it!=m.end();it++)
        cout<<(*it).first<<" "<<(*it).second<<endl;
    return 0;
}

主要方法有:insert(),clear(),erase(),find()等等,基本跟set一样。对于multimap使用方法跟map差不多一样。

std::pair主要的作用是将两个数据组合成一个数据,两个数据可以是同一类型或者不同类型。

例如 std::pair<int,float> 或者 std::pair<double,double>等。pair实质上是一个结构体,其主要的两个成员变量是first和second,这两个变量可以直接使用。初始化一个pair可以使用构造函数,也可以使用std::make_pair函数。

make_pair函数的定义如下:

[cpp] view plaincopyprint?

  1. template pair make_pair(T1 a, T2 b)
  2. {
  3. return pair(a, b);
  4. }
template pair make_pair(T1 a, T2 b)
{
    return pair(a, b);
}

所以m.insert(pair<string,double>("Luce",88.5));

与 m.insert(make_pair("Luce",88.5)); 是同样的效果。

示例:

[cpp] view plaincopyprint?

  1. int main()
  2. {
  3. typedef pair<string,double> lesson;
  4. typedef multimap<string,lesson> stu;
  5. stu a;
  6. a.insert(make_pair("Jack",lesson("math",90.5)));
  7. a.insert(make_pair("Jack",lesson("history",85.5)));
  8. a.insert(make_pair("Luce",lesson("math",99.0)));
  9. map<string,lesson>::iterator it;
  10. for(it=a.begin();it!=a.end();it++)
  11. cout<<(*it).first<<" "<<(*it).second.first<<" "<<(*it).second.second<<endl;
  12. return 0;
  13. }

set和map和pair 转自ACdreamers

时间: 2024-08-30 08:37:19

set和map和pair 转自ACdreamers的相关文章

map和pair配合使用,一个空格引发的血案

在map中可以嵌入pair使用,从而扩展map的灵活性, #include<map> using namespace std; map<CString, pair<CString, CString> > m_map; 注意红色部分的“空格”,不能缺少,否则会导致编译错误!!!

C++ map.insert: pair和make_pair区别

1 C++ map.insert: pair和make_pair区别 2 \********************************* 3 map<uint32_t, string> temp; 4 1. temp[1] = "template"; 5 2.temp.insert(pair<uint32_t, string>(1, "template")); 6 3.temp.insert(make_pair(1, "tem

c++map按value排序--将map的pair对保存到vector中,然后写比较仿函数+sort完成排序过程。

map是用来存放<key, value>键值对的数据结构,可以很方便快速的根据key查到相应的value.假如存储学生和其成绩(假定不存在重名,当然可以对重名加以区分),我们用map来进行存储就是个不错的选择. 我们这样定义,map<string, int>,其中学生姓名用string类型,作为Key:该学生的成绩用int类型,作为value.这样一来,我们可以根据学生姓名快速的查找到他的成绩. 但是,我们除了希望能够查询某个学生的成绩,或许还想看看整体的情况.我们想把所有同学和他

C语言 &#183; C++中map的用法详解

转载自:http://blog.csdn.net/sunquana/article/details/12576729 一.定义   (1) map<string,   int>   Map;     (2) 或者是:typedef   map<string,int>   Mymap;                       Mymap   Map; 二.插入数据  插入数据之前先说一下pair 和 make_pair 的用法pair是一个结构体,有first和second 两个

STL set,map

一.set和multisetset, multiset, map, multimap内部元素有序排列,新元素插入的位置取决于它的值,查找速度快.除了各容器都有的函数外,还支持以下成员函数:find: 查找等于某个值 的元素(x小于y和y小于x同时不成立即为相等)lower_bound : 查找某个下界upper_bound : 查找某个上界equal_range : 同时查找上界和下界count :计算等于某个值的元素个数(x小于y和y小于x同时不成立即为相等)insert: 用以插入一个元素或

详解map、multimap、unordered_map、unordered_multimap

详解map.multimap.unordered_map.unordered_multimap 相信有不少同学和我一样刚接触C++ STL,被其深深吸引.但是想弄懂每个模板类不是一个容易事.大家应该对vector.list.stack.queue等类比较了解了,所以今天详细介绍下几个很常用很强大但有点不太好懂的类map.multimap.unordered_map.unordered_multimap.乍一看都差不多都是什么map,但这肯定有所不同.下面就在一个一个讲解的同时,让大家了解这四个类

STL之map

参见http://www.cplusplus.com/reference/map/map/ template < class Key,                                     // map::key_type                     class T,                                        // map::mapped_type                     class Compare = less<

C++回顾map的用法

map<T, T>是C++的STL中存储key-value键值对数据结构的最基础的模板类,相对于multimap可以重复的key值,map的key是非重复的. C++的reference这样说明的: std::map is a sorted associative container that contains key-value pairs with unique keys. Keys are sorted by using the comparison function Compare.

从头认识java-15.1 填充容器(3)-填充Map

这一章节我们来讨论一下填充容器的还有一个方面Map.之前的两个章节我们都是用list来作为容器.这一章节我们使用Map. 还有在这里解释一下为什么一直都使用生成器这个东西,事实上他就是建造者设计模式,它基本的作用就是生产复杂的对象,并且满足各种需求的变化(灵活性). 还有为什么花这么多章节来讨论填充容器,主要由于填充容器包含比較多的知识点,知识点列举: (1)泛型 (2)建造者设计模式 (3)容器的填充方法(list 的add.map的put等) 进入主题,我们来讨论一下Map的填充 1.样例