青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

面對現實,超越自己
逆水行舟,不進則退
posts - 269,comments - 32,trackbacks - 0
C++ Maps & MultiMaps

C++ Maps
是一種關聯式容器,包含“關鍵字/值”對。
C++ Multimapsmaps很相似,但是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 );
   //插入valpos的后面,然后返回一個指向這個元素的迭代器
   void insert( input_iterator start, input_iterator end );
   //插入startend的元素到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的函數

MapSTL的一個關聯容器,它提供一對一(其中第一個可以稱為關鍵字,每個關鍵字只能在map中出現一次,第二個可能稱為該關鍵字的值)的數據處理能力,由于這個特性,map內部的實現自建一顆紅黑樹(一種非嚴格意義上的平衡二叉樹),這顆樹具有對數據自動排序的功能。

下面舉例說明什么是一對一的數據映射。比如一個班級中,每個學生的學號跟他的姓名就存在著一一映射的關系,這個模型用map可能輕易描述,很明顯學號用int描述,姓名用字符串(string)描述。

下面給出map描述代碼:

1.聲明方式:     

1       Map<intstring> mapStudent;

2.數據的插入

第一種:用insert函數插入pair數據

1       Map<intstring> mapStudent; 
2       mapStudent.insert(pair<intstring>(1, “student_one”)); 

      第二種:用insert函數插入value_type數據

1       Map<intstring> mapStudent; 
2       mapStudent.insert(map<intstring>::value_type (1, “student_one”)); 

     第三種:用數組方式插入數據

1       Map<intstring> mapStudent; 
2       mapStudent[1= “student_one”; 
3       mapStudent[2= “student_two”; 

    3. map的大小

1 Int nSize = mapStudent.size(); 

    4. 數據的遍歷

第一種:應用前向迭代器

1       map<intstring>::iterator iter; 
2       for(iter = mapStudent.begin(); iter !=   mapStudent.end(); iter++
3       Cout<<iter->first<<” ”<<iter->second<<end; 

     第二種:應用反相迭代器   

1       map<intstring>::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<intstring> mapStudent; 
 4       mapStudent.insert(pair<intstring>(1, “student_one”)); 
 5       mapStudent.insert(pair<intstring>(2, “student_two”)); 
 6       mapStudent.insert(pair<intstring>(3, “student_three”)); 
 7       map<intstring>::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中已經插入了12,3,4的話,如果lower_bound(2)的話,返回的2,而upper-bound2)的話,返回的就是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 

posted on 2012-06-04 16:57 王海光 閱讀(1861) 評論(0)  編輯 收藏 引用 所屬分類: STL
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲三级电影全部在线观看高清| 亚洲福利视频在线| 篠田优中文在线播放第一区| 亚洲精品日韩激情在线电影| 亚洲电影天堂av| 亚洲激情一区| 一本一本久久| 国产精品99久久久久久久vr| 亚洲欧美99| 亚洲在线观看视频| 欧美一区激情| 久久夜色精品国产亚洲aⅴ| 久久青草欧美一区二区三区| 欧美.www| 国产女优一区| 亚洲国产一区二区a毛片| 99在线热播精品免费| 亚洲欧美制服另类日韩| 久久九九99| 亚洲精品护士| 久久国产黑丝| 欧美午夜宅男影院| 亚洲第一福利在线观看| 一本色道久久88亚洲综合88| 欧美在线视频一区二区三区| 亚洲国产成人一区| 亚洲一区中文字幕在线观看| 久久亚裔精品欧美| 欧美午夜免费| 亚洲精品国产精品乱码不99按摩 | 欧美.www| 91久久线看在观草草青青| 亚洲视屏一区| 欧美福利影院| 在线成人性视频| 欧美一级免费视频| 亚洲激情电影在线| 久久久999精品免费| 欧美性猛交一区二区三区精品| 亚洲一区精品电影| 女人香蕉久久**毛片精品| 国产日本欧美一区二区| 99精品热视频| 久久婷婷久久| 欧美一区二视频| 国产精品国产三级国产| 亚洲精品日韩欧美| 欧美多人爱爱视频网站| 欧美专区在线| 国产欧美在线| 亚洲在线一区| 日韩一区二区精品视频| 欧美片在线观看| 亚洲精品乱码久久久久| 欧美本精品男人aⅴ天堂| 性欧美1819性猛交| 国产欧美日韩精品a在线观看| 国产精品免费一区二区三区在线观看 | 久久精品国产一区二区三| 亚洲国产小视频| 久久精品中文字幕免费mv| 在线视频你懂得一区二区三区| 亚洲人成在线播放| 麻豆成人91精品二区三区| 国语自产在线不卡| 久久天天狠狠| 久久久久一区二区| 影音先锋国产精品| 老司机免费视频久久| 久久久久久久精| 亚洲欧洲精品一区二区| 亚洲国产成人精品女人久久久| 亚洲国产精品成人综合| 久久久人成影片一区二区三区| 久久精品国产成人| 国产精品嫩草影院av蜜臀| 香蕉国产精品偷在线观看不卡| 久久婷婷久久一区二区三区| 久久精品欧美日韩| 亚洲国产精品欧美一二99| 老**午夜毛片一区二区三区| 久久综合狠狠综合久久综青草 | 欧美日韩亚洲激情| 亚洲日本一区二区| 亚洲日韩第九十九页| 欧美日韩国产影院| 亚洲无限av看| 欧美影院在线播放| 亚洲精品一品区二品区三品区| 亚洲一区二区高清| 亚洲欧美日韩一区二区| 黑人操亚洲美女惩罚| 久久精品亚洲一区二区| 久久亚洲春色中文字幕久久久| 国产精品久久久久久久久久久久久 | 国产日韩一区| 欧美777四色影视在线| 欧美日韩一区综合| 久久久久久久久岛国免费| 欧美成人午夜77777| 午夜亚洲福利在线老司机| 毛片av中文字幕一区二区| 亚洲女人av| 久久一区激情| 午夜精品亚洲| 久久亚洲春色中文字幕久久久| 国产日韩精品视频一区二区三区| 91久久国产综合久久蜜月精品| 欧美一级片久久久久久久| 久久在线精品| 欧美制服第一页| 欧美日韩1080p| 麻豆freexxxx性91精品| 久久久一本精品99久久精品66| 国产精品久久久亚洲一区| 在线看不卡av| 亚洲欧美制服另类日韩| 亚洲精品一区二区三区在线观看| 久久久久久自在自线| 欧美精品免费观看二区| 久久天天躁狠狠躁夜夜av| 国产精品一卡| 在线亚洲精品| 亚洲图片欧美午夜| 蜜臀久久久99精品久久久久久| 亚洲国产精品ⅴa在线观看 | 欧美主播一区二区三区| 欧美激情亚洲另类| 欧美成人午夜影院| 一区福利视频| 久久精品视频播放| 久久婷婷蜜乳一本欲蜜臀| 国产精一区二区三区| 国产精品99久久久久久人 | 国产手机视频一区二区| 亚洲高清资源| 91久久久久久| 欧美v日韩v国产v| 欧美国产欧美亚洲国产日韩mv天天看完整 | 久久精品久久综合| 国产精品高清在线观看| 日韩小视频在线观看| 亚洲人成网站999久久久综合| 亚洲国产成人精品久久久国产成人一区| 久久成人18免费观看| 欧美一区激情| 国产一区二区三区久久悠悠色av | 久久夜色精品| 免费成人av在线看| 亚洲国产毛片完整版| 美女视频黄免费的久久| 美女免费视频一区| 亚洲成人在线视频播放| 麻豆精品在线观看| 亚洲美女一区| 欧美一区亚洲二区| 在线成人欧美| 欧美啪啪一区| 午夜日韩av| 免费亚洲视频| 欧美一区二区三区啪啪| 亚洲美女av在线播放| 欧美在线观看视频| 久久午夜av| 妖精成人www高清在线观看| 国产精品成人一区二区网站软件| 久久蜜桃资源一区二区老牛 | 精品91免费| 欧美xxxx在线观看| 亚洲特级毛片| 久久综合中文色婷婷| 亚洲电影中文字幕| 欧美精品在线免费播放| 亚洲综合视频1区| 欧美阿v一级看视频| 一区二区动漫| 韩国av一区二区三区| 欧美成人精品| 在线亚洲欧美视频| 欧美成人中文| 羞羞视频在线观看欧美| 亚洲国产mv| 国产乱码精品1区2区3区| 久久网站热最新地址| 99精品视频免费观看视频| 久久一日本道色综合久久| 亚洲一区二区三区国产| 国产日韩精品综合网站| 久久久久中文| 亚洲免费伊人电影在线观看av| 日韩午夜免费| 国产欧美欧美| 欧美成人一区二区三区| 亚洲女人av| 亚洲精品视频在线观看网站| 久久久久综合| 久久成人免费电影| 亚洲人成高清| 国产日韩专区| 欧美日韩在线不卡|