c++ STL map容器成员函数
map容器用于查找,设置键值和元素值,输入键值,就能得到元素值。map对象中的元素时刻都是有序的,除非无序插入的。它是用平衡树创建的。查找很快。
|
函数 |
描述,注意有r的地方都是不能用it代替的。 |
|
map (comp,alloc) map (it first, it last, comp,alloc) map (map& x) |
Comp为比较函数,用于排序,alloc不用鸟它。两个参数有默认值,可不填,按默认的。创建空map。 用一段元素填充,并设置排序函数。 拷贝x中的元素并创建新map。估计新的map对象的comp也是和x一样。 |
|
mapped_type& m.at (key_type& k) |
返回键值k对应的元素值,回值引用类型的。 |
|
it m.begin() |
返回第1个元素的地址,也就是有序的首个元素。 |
|
const_it m.cbegin() |
功能同上,但是不能修改此元素。 |
|
const_it m.cend() |
返回最后一个元素的下一个元素的地址,不可修改元素值。若容器为空,则返回同cbegin。 |
|
Void m.clear() |
清空容器内所有元素。 |
|
int m.count(key_type& k) |
若键值k对应的元素存在,则返回1,否则0。 |
|
const_rit m.crbegin() |
返回最后一个元素的地址。 |
|
const_rit m.crend() |
返回首个元素的前一个元素地址,该地址无元素。 |
|
pair<it,bool> m.emplace (键值,单个元素) |
插入。若键值不存在,则插入,并返回一对参数分别为元素地址和true。否则返回已存在的那个元素地址和false。 |
|
it m.emplace_hint (it pos,单个元素) |
插入。若键值不存在,则插入到pos所指位置,并返回该地址。否则返回已存在的那个元素地址。这样插就不一定会保证有序了。 |
|
bool m.empty() |
若容器为空,则返回true,否则false。 |
|
it m.end() |
返回最后一个元素的下一个元素地址。该地址无元素。 |
|
pair<it,it> m.equal_range (k) |
返回键值k的元素位置,包括首地址和尾地址,这两个指针内只有一个元素。若不存在k,则返回两个begin的地址。 |
|
void m.erase (it pos) int m.erase (k) void m.erase (it first, it last) |
删除pos地址的元素。 删除键值为k的元素,返回剩余元素个数。 删除一段元素,last所指元素不删。 |
|
it m.find(k) |
寻找键值为k的元素,并用返回其地址。找不到则返回end的地址。 |
|
Get_allocator |
不懂 |
|
pair<it,bool> m.insert (val) it m.insert (it pos, val) void m.insert (It first, It last) |
插入元素。例如mymap.insert ( std::pair<char,int>('a',100) )并返回其地址和true。Pair也可以定义成一个变量形式的。 插入val到指定的pos位置,返回pos。若失败,it指向已存在的那个元素。 将first到last的一段元素插入进去。 |
|
key_compare m.key_comp() |
返回m的比较对象。类似于返回了一个函数,此函数可用来比较两个map中的元素大小,参数是两个键值。 |
|
It m.lower_bound (k) |
返回键值k的元素的首地址。 |
|
Int m.max_size() |
返回能容纳元素的数量。 |
|
map& operator= (const map& x) |
复制。将一个map对象复制到另一对象。注:1对象可包含多个元素。 |
|
mapped_type& operator[] (const key_type& k) |
可以用下标法查找元素。比如m[10]表示返回键值为10的元素,不输出键值。 |
|
rit m.rbegin() |
返回反向的首元素的地址,得用反向指针。 |
|
rit m.rend() |
返回正向的首元素的地址,也就是反向的尾地址了。 |
|
int m.size() |
返回map中已存在元素的数量。 |
|
It m.upper_bound (k) |
返回键值为k的元素的末地址,该地址是其他元素。 |
|
void m.swap(map& x) |
将两个map对象换名字。 |
|
value_compare m.value_comp() |
返回元素比较函数,可以用于比较值大小。例如mymap.value_comp()(*it, highest)这里highest的类型是pair型的,即std::pair<char,int> |
|
bool operator== ( const map<Key,T,Compare,Alloc>& lhs,const map<Key,T,Compare,Alloc>& rhs ); bool operator!= ( const map<Key,T,Compare,Alloc>& lhs,const map<Key,T,Compare,Alloc>& rhs ); bool operator< ( const map<Key,T,Compare,Alloc>& lhs,const map<Key,T,Compare,Alloc>& rhs ); bool operator<= ( const map<Key,T,Compare,Alloc>& lhs, const map<Key,T,Compare,Alloc>& rhs ); bool operator> ( const map<Key,T,Compare,Alloc>& lhs, const map<Key,T,Compare,Alloc>& rhs ); bool operator>= ( const map<Key,T,Compare,Alloc>& lhs,const map<Key,T,Compare,Alloc>& rhs ) |
|
|
void swap (map& x, map& y) |
交换两个map对象的名字,两对象必须是同类型的。 |
c++ STL map容器成员函数的更多相关文章
- c++ STL stack容器成员函数
这是后进先出的栈,成员函数比较简单,因为只能操作栈顶的元素.不提供清除什么的函数. 函数 描述 bool s.empty() 栈是否为空(即size=0).若空,返回true,否则,false. vo ...
- c++ STL deque容器成员函数
deque是双向队列,即可以在头部插入删除,也可以在尾部插入删除.内部并不连续,这一点和vector并不一样.可能第1个元素和第2个元素的地址是不连在一起的.在使用时用it迭代器会安全一点. 这是c+ ...
- c++ STL list容器成员函数
list是一个双链表. 函数 描述 void l.assign (int n, const val) void l.assign (it first, it last) 将链表l初始化为n个相同的va ...
- 详解C++ STL map 容器
详解C++ STL map 容器 本篇随笔简单讲解一下\(C++STL\)中的\(map\)容器的使用方法和使用技巧. map容器的概念 \(map\)的英语释义是"地图",但\( ...
- C++ STL map容器值为指针时怎么释放内存
最近在使用STL中map时,遇到了一个问题,就是当map中值为指针对象时怎么释放内存? // 站点与TCP连接映射表 (key为ip_port_stationCode, value为 clientSo ...
- c++使用map保存成员函数地址
note 本基于c++11介绍一种使用map保存成员函数地址 可避免使用 if 和 switch 配置灵活 方便, 代码维护效率高 结果: 范例开始 头文件包含 #include <iostre ...
- stl::map之const函数访问
如何在const成员数中访问stl::map呢?例如如下代码: string ConfigFileManager::MapQueryItem(const string& name) const ...
- STL --> map容器
map容器 一.map简介 map是一类关联式容器.它的特点是增加和删除节点对迭代器的影响很小,除了那个操作节点,对其他的节点都没有什么影响.对于迭代器来说,可以修改实值,而不能修改key. 二.ma ...
- STL容器 成员函数 时间复杂度表
Sequence containers Associative containers Headers <vector> <deque> <list> <s ...
随机推荐
- uoj #185. 【ZJOI2016】小星星
#185. [ZJOI2016]小星星 小Y是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有 nn 颗小星星,用 mm 条彩色的细线串了起来,每条细线连着两颗小星星.有一天她发现,她的饰品被破坏 ...
- [转]Xcode概览:调试应用程序
原文网址: blog.csdn.net/fhbystudy/article/details/12856261 本文由CocoaChina翻译组成员Creolophus(github主页)翻译自苹果官方 ...
- iOS拼图
#import "ViewController.h" @interface ViewController () @end @implementation ViewContro ...
- BZOJ 4919: [Lydsy1706月赛]大根堆 启发式合并
我不会告诉你这是线段树合并的好题的... 好吧我们可以搞一个multiset在dfs时求出LIS(自带二分+排序)进行启发式合并,轻松加愉悦... #include<cstdio> #in ...
- ACM-ICPC 2018 南京赛区网络预赛 Lpl and Energy-saving Lamps (线段树:无序数组找到第一个小于val)
题意:n个房间,每个房间有ai盏旧灯,每个月可以买m盏新灯,要求:按房间顺序换灯,如果剩下的新灯数目大于ai,那么进行更换,否则跳过该房间,判断下一个房间.如果所有房间都换完灯,那么久不会再买新灯. ...
- 高并发web系统优化总结
1.背景 因为业务需要,搭建了一个系统,系统主要由两部分组成,web页面和数据库. mysql大概2万条数据,其中有一个字段是click_num点击次数,php页面会取点击次数最小的一条记录去进行操作 ...
- spark_运行spark-shell报错_javax.jdo.JDOFatalDataStoreException: Unable to open a test connection to the given database.
error: # ./spark-shell Caused by: javax.jdo.JDOFatalDataStoreException: Unable to open a test connec ...
- Chapter10
package scala import java.io.{PrintStream, PrintWriter}import java.util.Date import scala.util.loggi ...
- JS——定时器
定时器在JS中的作用: 1)制作动画.时钟.倒计时 2)异步操作 3)函数缓冲与节流 定时器类型: 1)setTimeout 只执行一次的定时器 2)clearTimeout 关闭只执行一次的定时器 ...
- Sqoop Import HDFS
Sqoop import应用场景——密码访问 注:测试用表为本地数据库中的表 1.明码访问 sqoop list-databases \ --connect jdbc:mysql://202.193. ...