C++ Maps MultiMaps
C++ Maps是一種關聯式容器,包含“關鍵字/值”對。 C++ Multimaps和maps很相似,但是MultiMaps允許重復的元素。 1.begin()?返回指向map頭部的迭代器 2.clear()?刪除所有元素 3.count()?返回指定元素出現的次數 ???語法: ???size_type count( const KEY_TYPE &key ); ???//返回map中鍵值等于key的元素的個數 4.empty()?如果map為空則返回true 5.end()?返回指向map末尾的迭代器 6.equal_range()?返回特殊條目的迭代器對 ???語法: ???pair equal_range( const KEY_TYPE &key ); ???返回兩個迭代器,指向第一個鍵值為key的元素和指向最后一個鍵值為key的元素 7.erase()?刪除一個元素 ???語法: ???void erase( iterator i );?//刪除i元素 ???void erase( iterator start, iterator end );?//刪除從start開始到end(不包括end)結束的元素 ???size_type erase( const key_type &key ); ???//刪除等于key值的所有元素(返回被刪除的元素的個數) 8.find()?查找一個元素 ???語法: iterator find( const key_type &key ); ???查找等于key值的元素,并返回指向該元素的迭代器; ???//如果沒有找到,返回指向集合最后一個元素的迭代器. 9.get_allocator()?返回map的配置器 10.insert()?插入元素 ???語法: ???iterator insert( iterator pos, const pair<KEY_TYPE,VALUE_TYPE> &val ); ???//插入val到pos的后面,然后返回一個指向這個元素的迭代器 ???void insert( input_iterator start, input_iterator end ); ???//插入start到end的元素到map中 ???pair<iterator, bool> insert( const pair<KEY_TYPE,VALUE_TYPE> &val ); ???//只有在val不存在時插入val。返回指向被插入元素的迭代器和描述是否插入的bool值 11.key_comp()?返回比較元素key的函數 ???語法: ???key_compare key_comp(); ???//返回一個用于元素間值比較的函數對象 12.lower_bound()?返回鍵值>=給定元素的第一個位置 ???語法: ???iterator lower_bound( const key_type &key ); ???//返回一個指向大于或者等于key值的第一個元素的迭代器 13.max_size()?返回可以容納的最大元素個數 14.rbegin()?返回一個指向map尾部的逆向迭代器 15.rend()?返回一個指向map頭部的逆向迭代器 16.size()?返回map中元素的個數 17.swap()?交換兩個map ???語法: ???void swap( map &obj ); ???//swap()交換obj和現map中的元素 18.upper_bound()?返回鍵值>給定元素的第一個位置 ???語法: ???iterator upwer_bound( const key_type &key ); ???//返回一個指向大于key值的第一個元素的迭代器 19.value_comp()?返回比較元素value的函數 ???語法: ???value_compare value_comp(); //返回一個用于比較元素value的函數
Map是STL的一個關聯容器,它提供一對一(其中第一個可以稱為關鍵字,每個關鍵字只能在map中出現一次,第二個可能稱為該關鍵字的值)的數據處理能力,由于這個特性,map內部的實現自建一顆紅黑樹(一種非嚴格意義上的平衡二叉樹),這顆樹具有對數據自動排序的功能。
下面舉例說明什么是一對一的數據映射。比如一個班級中,每個學生的學號跟他的姓名就存在著一一映射的關系,這個模型用map可能輕易描述,很明顯學號用int描述,姓名用字符串(string)描述。
下面給出map描述代碼:
1.聲明方式:?????
1???????Map<int,?string>?mapStudent;
2.數據的插入
第一種:用insert函數插入pair數據
1???????Map<int,?string>?mapStudent;?
2???????mapStudent.insert(pair<int,?string>(1,?“student_one”));?
??????第二種:用insert函數插入value_type數據
1???????Map<int,?string>?mapStudent;?
2???????mapStudent.insert(map<int,?string>::value_type?(1,?“student_one”));?
?????第三種:用數組方式插入數據
1???????Map<int,?string>?mapStudent;?
2???????mapStudent[1]?=?“student_one”;?
3???????mapStudent[2]?=?“student_two”;?
????3. map的大小
1?Int?nSize?=?mapStudent.size();?
????4.?數據的遍歷
第一種:應用前向迭代器
1???????map<int,?string>::iterator?iter;?
2???????for(iter?=?mapStudent.begin();?iter?!=???mapStudent.end();?iter++)?
3???????Cout<<iter->first<<”?”<<iter->second<<end;?
?????第二種:應用反相迭代器???
1???????map<int,?string>::reverse_iterator?iter;?2???????for(iter?=?mapStudent.rbegin();?iter?!=?mapStudent.rend();?iter++)?
3???????Cout<<iter->first<<”?”<<iter->second<<end;
第三種:用數組方式?????
1???????int?nSize?=?mapStudent.size()?2???????for(int?nIndex?=?1;?nIndex?<=?nSize;?nIndex++)?
3???????Cout<<mapStudent[nIndex]<<end;
5.?數據的查找(包括判定這個關鍵字是否在map中出現)
第一種:用count函數來判定關鍵字是否出現,但是無法定位數據出現位置
第二種:用find函數來定位數據出現位置它返回的一個迭代器,
當數據出現時,它返回數據所在位置的迭代器,如果map中沒有要查找的數據,它返回的迭代器等于end函數返回的迭代器
?1?int?main()?
?2?{?
?3???????Map<int,?string>?mapStudent;?
?4???????mapStudent.insert(pair<int,?string>(1,?“student_one”));?
?5???????mapStudent.insert(pair<int,?string>(2,?“student_two”));?
?6???????mapStudent.insert(pair<int,?string>(3,?“student_three”));?
?7???????map<int,?string>::iterator?iter;?
?8???????iter?=?mapStudent.find(1);?
?9???????if(iter?!=?mapStudent.end())?
10???????{?
11??????????Cout<<”Find,?the?value?is?”<<iter->second<<endl;?
12???????}?
13???????Else?
14???????{?
15??????????Cout<<”Do?not?Find”<<endl;?
16???????}?
17?}?
第三種:這個方法用來判定數據是否出現
Lower_bound函數用法,這個函數用來返回要查找關鍵字的下界(是一個迭代器)
Upper_bound函數用法,這個函數用來返回要查找關鍵字的上界(是一個迭代器)
例如:map中已經插入了1,2,3,4的話,如果lower_bound(2)的話,返回的2,而upper-bound(2)的話,返回的就是3
Equal_range函數返回一個pair,pair里面第一個變量是Lower_bound返回的迭代器,pair里面第二個迭代器是Upper_bound返回的迭代器,如果這兩個迭代器相等的話,則說明map中不出現這個關鍵字,程序說明
1?mapPair?=?mapStudent.equal_range(2);?
2?if(mapPair.first?==?mapPair.second)?
3?cout<<”Do?not?Find”<<endl;?
6.?數據的清空與判空
清空map中的數據可以用clear()函數,判定map中是否有數據可以用empty()函數,它返回true則說明是空map
7.?數據的刪除
這里要用到erase函數,它有三個重載了的函數
迭代器刪除???
1????iter?=?mapStudent.find(1);?2????mapStudent.erase(iter);
用關鍵字刪除??
1?Int?n?=?mapStudent.erase(1);//如果刪除了會返回1,否則返回0
用迭代器,成片的刪除
1?mapStudent.earse(mapStudent.begin(),??mapStudent.end());?
2?//成片刪除要注意的是,也是STL的特性,刪除區間是一個前閉后開的集合
3
總結
以上是生活随笔為你收集整理的C++ Maps MultiMaps的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: HDU 1495(非常可乐)
- 下一篇: Countries