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

        map映照容器的元素數(shù)據(jù)是一個鍵值和一個映照數(shù)據(jù)組成的,鍵值與映照數(shù)據(jù)之間具有一一映照的關(guān)系。
        map映照容器的數(shù)據(jù)結(jié)構(gòu)是采用紅黑樹來實現(xiàn)的,插入鍵值的元素不允許重復(fù),比較函數(shù)只對元素的鍵值進行比較,元素的各項數(shù)據(jù)可通過鍵值檢索出來。
        使用map容器需要頭文件包含語句“#include<map>”, map文件也包含了對multimap多重映照容器的定義。
        
1、map創(chuàng)建、元素插入和遍歷訪問
        
創(chuàng)建map對象,鍵值與映照數(shù)據(jù)的類型由自己定義。在沒有指定比較函數(shù)時,元素的插入位置是按鍵值由小到大插入到黑白樹中去的,下面這個程序詳細說明了如何操作map容器。
 1#include <map>
 2#include <string>
 3#include <iostream>
 4
 5using std :: cout ;
 6using std :: endl ;
 7using std :: string ;
 8using std :: map ;
 9
10int main()
11{
12     //定義map對象,當前沒有任何元素
13     map<string,float> m ;
14     
15     //插入元素,按鍵值的由小到大放入黑白樹中
16     m["Jack"= 98.5 ;
17     m["Bomi"= 96.0 ;
18     m["Kate"= 97.5 ;
19     
20     //先前遍歷元素
21     map<string,float> :: iterator it ;
22     for(it = m.begin() ; it != m.end() ; it ++)
23     {
24          cout << (*it).first << " : " << (*it).second << endl ;
25     }

26     
27     return 0 ;
28}

29
        運行結(jié)果:
                          Bomi :96
                          Jack  :98.5
                          Kate  :97.5
        程序編譯試,會產(chǎn)生代號為“warning C4786” 的警告, “4786” 是標記符超長警告的代號。可以在程序的頭文件包含代碼的前面使用"#pragma waring(disable:4786)" 宏語句,強制編譯器忽略該警告。4786號警告對程序的正確性和運行并無影響。
2、刪除元素
        map映照容器的 erase() 刪除元素函數(shù),可以刪除某個迭代器位置上的元素、等于某個鍵值的元素、一個迭代器區(qū)間上的所有元素,當然,也可使用clear()方法清空map映照容器。
        下面這個程序演示了刪除map容器中鍵值為28的元素:
 1#include <map>
 2#include <string>
 3#include <iostream>
 4
 5using std :: cout ;
 6using std :: endl ;
 7using std :: string ;
 8using std :: map ;
 9
10int main()
11{
12    //定義map對象,當前沒有任何元素
13    map<intchar> m ;
14    //插入元素,按鍵值的由小到大放入黑白樹中
15    m[25= 'm' ;
16    m[28= 'k' ;
17    m[10= 'x' ;
18    m[30= 'a' ;
19    //刪除鍵值為28的元素
20    m.erase(28) ;
21    //向前遍歷元素
22    map<intchar> :: iterator it ;
23    for(it = m.begin() ; it != m.end() ; it ++)
24    {
25        //輸出鍵值與映照數(shù)據(jù)
26        cout << (*it).first << " : " << (*it).second << endl ;
27    }

28    return 0 ;
29}

30
運行結(jié)果:
                     10 : x
                     25 : m
                     30 : a
3、元素反向遍歷
      可以用反向迭代器reverse_iterator反向遍歷map映照容器中的數(shù)據(jù),它需要rbegin()方法和rend()方法指出反向遍歷的起始位置和終止位置。
 1#include <map>
 2#include <string>
 3#include <iostream>
 4
 5using std :: cout ;
 6using std :: endl ;
 7using std :: string ;
 8using std :: map ;
 9
10int main()
11{
12    //定義map對象,當前沒有任何元素
13    map<intchar> m ;
14    //插入元素,按鍵值的由小到大放入黑白樹中
15    m[25= 'm' ;
16    m[28= 'k' ;
17    m[10= 'x' ;
18    m[30= 'a' ;
19    //反向遍歷元素
20    map<intchar> :: reverse_iterator rit ;
21    for( rit = m.rbegin() ; rit != m.rend() ; rit ++)
22    {
23        //輸入鍵值與映照數(shù)據(jù)
24        cout << (*rit).first << " : " << (*rit).second << endl ;
25    }

26    return 0 ;
27}

28
運行結(jié)果:
                  30 : a
                  28 : k
                  25 : m
                  10 : x
4、元素的搜索
      
使用find()方法來搜索某個鍵值,如果搜索到了,則返回該鍵值所在的迭代器位置,否則,返回end()迭代器位置。由于map采用黑白樹數(shù)據(jù)結(jié)構(gòu)來實現(xiàn),所以搜索速度是極快的。
       下面這個程序搜索鍵值為28的元素:
 1#include <map>
 2#include <string>
 3#include <iostream>
 4
 5using std :: cout ;
 6using std :: endl ;
 7using std :: string ;
 8using std :: map ;
 9
10int main()
11{
12    //定義map對象,當前沒有任何元素
13    map<intchar> m ;
14    //插入元素,按鍵值的由小到大放入黑白樹中
15    m[25= 'm' ;
16    m[28= 'k' ;
17    m[10= 'x' ;
18    m[30= 'a' ;
19    map<intchar> :: iterator it ;
20    it = m.find(28) ;
21    if(it != m.end())  //搜索到該鍵值
22            cout << (*it).first << " : " << ( *it ).second << endl ;
23    else
24            cout << "not found it" << endl ;
25    return 0 ;
26}

27
5、自定義比較函數(shù)
       
將元素插入到map中去的時候,map會根據(jù)設(shè)定的比較函數(shù)將該元素放到該放的節(jié)點上去。在定義map的時候,如果沒有指定比較函數(shù),那么采用默認的比較函數(shù),即按鍵值由小到大的順序插入元素。在很多情況下,需要自己編寫比較函數(shù)。
        編寫方法有兩種。
        (1)如果元素不是結(jié)構(gòu)體,那么,可以編寫比較函數(shù)。下面這個程序編寫的比較規(guī)則是要求按鍵值由大到小的順序?qū)⒃夭迦氲絤ap中
 1#include <map>
 2#include <string>
 3#include <iostream>
 4
 5using std :: cout ;
 6using std :: endl ;
 7using std :: string ;
 8using std :: map ;
 9
10//自定義比較函數(shù) myComp
11struct myComp
12{
13    bool operator() (const int &a, const int &b)
14    {
15        if(a != b) return a > b ;
16        else  return a > b ;
17    }

18}
 ;
19
20int main()
21{
22    //定義map對象,當前沒有任何元素
23    map<intchar> m ;
24    //插入元素,按鍵值的由小到大放入黑白樹中
25    m[25= 'm' ;
26    m[28= 'k' ;
27    m[10= 'x' ;
28    m[30= 'a' ;
29    //使用前向迭代器中序遍歷map
30    map<intchar,myComp> :: iterator it ;
31    for(it = m.begin() ; it != m.end() ; it ++)
32            cout << (*it).first << " : " << (*it).second << endl ;
33    return 0 ;
34}

35
運行結(jié)果:
                  30 :a
                  28 :k
                  25 :m
                  10 :x
       (2)如果元素是結(jié)構(gòu)體,那么,可以直接把比較函數(shù)寫在結(jié)構(gòu)體內(nèi)。下面的程序詳細說明了如何操作:
 1#include <map>
 2#include <string>
 3#include <iostream>
 4
 5using std :: cout ;
 6using std :: endl ;
 7using std :: string ;
 8using std :: map ;
 9
10struct Info
11{
12    string name ;
13    float score ;
14    //重載 “<”操作符,自定義排列規(guī)則
15    bool operator < (const Info &a) const
16    {
17        //按score由大到小排列。如果要由小到大排列,使用“>”號即可
18        return a.score < score ;
19    }

20}
 ;
21
22int main()
23{
24    //定義map對象,當前沒有任何元素
25    map<Info, int> m ;
26    //定義Info結(jié)構(gòu)體變量
27    Info info ;
28    //插入元素,按鍵值的由小到大放入黑白樹中
29    info.name = "Jack" ;
30    info.score = 60 ;
31    m[info] = 25 ;
32    info.name = "Bomi" ;
33    info.score = 80 ;
34    m[info] = 10 ;
35    info.name = "Peti" ;
36    info.score = 66.5 ;
37    m[info] = 30 ;
38    //使用前向迭代器中序遍歷map
39    map<Info,int> :: iterator it ;
40    for(it = m.begin() ; it != m.end() ; it ++)
41    {
42            cout << (*it).second << " : " ;
43            cout << ((*it).first).name << " : " << ((*it).first).score << endl ;
44    }

45    return 0 ;
46}

47
運行結(jié)果:
                  10 :Bomi   80
                  30 :Peti     66.5
                  25 :Jack    60
6、用map實現(xiàn)數(shù)字分離
      對數(shù)字的各位進行分離,采用取余等數(shù)學(xué)方法是很耗時的。而把數(shù)字當成字符串,使用map的映照功能,很方便地實現(xiàn)了數(shù)字分離。下面這個程序?qū)⒁粋€字符串中的字符當成數(shù)字,并將各位的數(shù)值相加,最后輸出各位的和。
 1#include <string>
 2#include <map>
 3#include <iostream>
 4
 5using std :: cout ;
 6using std :: endl ;
 7using std :: string ;
 8using std :: map ;
 9
10int main()
11{
12    //定義map對象,當前沒有任何元素
13    map<charint> m ;
14
15    //賦值:字符映射數(shù)字
16    m['0'= 0 ;
17    m['1'= 1 ;
18    m['2'= 2 ;
19    m['3'= 3 ;
20    m['4'= 4 ;
21    m['5'= 5 ;
22    m['6'= 6 ;
23    m['7'= 7 ;
24    m['8'= 8 ;
25    m['9'= 9 ;
26    /*上面的10條賦值語句可采用下面這個循環(huán)簡化代碼編寫
27    for(int j = 0 ; j < 10 ; j++)
28    {
29            m['0' + j] = j ;
30    }
31    */

32    string sa, sb ;
33    sa = "6234" ;
34    int i ;
35    int sum = 0 ;
36    for ( i = 0 ; i < sa.length() ; i++ )
37            sum += m[sa[i]] ;
38    cout << "sum = " << sum << endl ;
39    return 0 ;
40}

41
7、數(shù)字映照字符的map寫法
      
在很多情況下,需要實現(xiàn)將數(shù)字映射為相應(yīng)的字符,看看下面的程序:
 1#include <string>
 2#include <map>
 3#include <iostream>
 4
 5using std :: cout ;
 6using std :: endl ;
 7using std :: string ;
 8using std :: map ;
 9
10int main()
11{
12    //定義map對象,當前沒有任何元素
13    map<intchar> m ;
14
15    //賦值:字符映射數(shù)字
16    m[0= '0' ;
17    m[1= '1' ;
18    m[2= '2' ;
19    m[3= '3' ;
20    m[4= '4' ;
21    m[5= '5' ;
22    m[6= '6' ;
23    m[7= '7' ;
24    m[8= '8' ;
25    m[9= '9' ;
26    /*上面的10條賦值語句可采用下面這個循環(huán)簡化代碼編寫
27    for(int j = 0 ; j < 10 ; j++)
28    {
29            m[j] = '0' + j ;
30    }
31    */

32    int n = 7 ;
33    string s = "The number is " ;
34    cout << s + m[n] << endl ;
35    return 0 ;
36}

37
運行結(jié)果:
                  The number is 7
posted on 2010-05-16 10:01 Vontroy 閱讀(6201) 評論(0)  編輯 收藏 引用 所屬分類: C++

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产精品成人综合| 99精品福利视频| 夜夜嗨av一区二区三区网页| 欧美三级视频在线| 午夜欧美精品久久久久久久| 久久精品在这里| 亚洲婷婷综合久久一本伊一区| 亚洲自啪免费| 亚洲欧美99| 欧美在线啊v一区| 亚洲人久久久| 亚洲欧美99| 亚洲裸体视频| 久久久91精品国产一区二区三区| 亚洲麻豆av| 欧美一区二区三区播放老司机| 亚洲精品一区二区三区樱花| 亚洲欧美日产图| 日韩视频精品| 久久精品亚洲一区二区| 亚洲中字黄色| 欧美精品免费视频| 另类专区欧美制服同性| 欧美性猛交xxxx免费看久久久| 女女同性精品视频| 国产麻豆视频精品| 一本不卡影院| 亚洲精品综合| 久久蜜桃资源一区二区老牛 | 欧美日韩中文字幕在线| 老色批av在线精品| 国产麻豆精品视频| 亚洲一区二区三区高清 | 另类成人小视频在线| 午夜亚洲性色福利视频| 欧美精品一区二区三区在线看午夜| 久久夜色撩人精品| 亚洲欧美偷拍卡通变态| 在线视频精品一| 欧美成人免费在线视频| 久久综合九色欧美综合狠狠| 国产精品一区二区你懂的| 日韩一二三区视频| 99精品国产99久久久久久福利| 噜噜噜躁狠狠躁狠狠精品视频| 久久久一本精品99久久精品66| 国产欧美日韩亚洲一区二区三区| 亚洲香蕉视频| 香蕉国产精品偷在线观看不卡| 国产精品久久久久久久app| 夜夜爽www精品| 亚洲欧美影音先锋| 久久阴道视频| 欧美日韩中字| 一区二区三区日韩欧美| 亚洲伊人色欲综合网| 欧美视频一区| 亚洲无亚洲人成网站77777| 午夜精品在线视频| 国产亚洲午夜| 久久久亚洲午夜电影| 欧美激情第3页| 99国产成+人+综合+亚洲欧美| 欧美日韩ab| 在线视频日本亚洲性| 亚洲欧美日韩国产综合精品二区| 国产精品色午夜在线观看| 午夜精品一区二区三区在线| 久久免费国产精品| 亚洲高清视频一区| 欧美日韩福利| 亚洲欧美激情视频| 久久中文欧美| 日韩一级在线| 国产精品视频免费| 久久久久久久999精品视频| 欧美韩日视频| 亚洲欧美电影在线观看| 狠狠色伊人亚洲综合成人| 免费一级欧美片在线观看| 亚洲乱码精品一二三四区日韩在线| 亚洲欧美日韩国产中文在线| 亚洲高清av| 国产精品日韩二区| 久久亚洲精品中文字幕冲田杏梨| 亚洲精品美女| 久久精品国产亚洲一区二区| 亚洲激情电影中文字幕| 欧美视频国产精品| 久久成人综合网| 亚洲精品久久久久久久久久久久| 午夜一区在线| 日韩视频欧美视频| 国产亚洲精品久久久久婷婷瑜伽 | 亚洲精品女av网站| 国产精品美女久久福利网站| 久久国产精品久久国产精品| 亚洲精品国产精品国自产观看| 欧美中文在线免费| 欧美国产日韩一区二区三区| 亚洲婷婷综合色高清在线| 免费欧美日韩| 欧美伊人久久大香线蕉综合69| 精品粉嫩aⅴ一区二区三区四区| 亚洲在线观看免费| 亚洲国产精品激情在线观看| 欧美一级视频免费在线观看| 亚洲欧洲日本专区| 国产视频在线观看一区二区| 欧美日韩精品高清| 久久综合网络一区二区| 亚洲女同同性videoxma| 日韩亚洲欧美成人| 亚洲国产国产亚洲一二三| 久久精品国产91精品亚洲| 亚洲一区二区三区精品视频| 欧美 日韩 国产 一区| 午夜精品久久99蜜桃的功能介绍| 亚洲日本欧美天堂| 欧美大片第1页| 久久综合国产精品| 久久精品国语| 久久久久网址| 欧美成人精品高清在线播放| 欧美在线免费观看| 亚洲综合国产激情另类一区| 99精品热视频| 亚洲美女av在线播放| 亚洲国产精品久久久久久女王| 久久久久这里只有精品| 午夜久久美女| 久久国产精彩视频| 久久xxxx| 久久免费的精品国产v∧| 久久久99爱| 亚洲国产一区二区三区青草影视 | 亚洲国产1区| 嫩模写真一区二区三区三州| 久久精选视频| 久久视频在线看| 久久综合一区二区三区| 老巨人导航500精品| 久久久久在线观看| 免费成人在线视频网站| 你懂的网址国产 欧美| 亚洲大胆人体在线| 欧美丰满高潮xxxx喷水动漫| 欧美国产日韩视频| 亚洲高清一二三区| 亚洲精品一区二区三区四区高清 | 亚洲美女在线国产| 一二三区精品福利视频| 亚洲视频大全| 欧美有码在线视频| 久久久亚洲精品一区二区三区| 久久香蕉国产线看观看网| 欧美不卡视频一区| 亚洲精品乱码| 午夜精品久久久久久久99樱桃| 欧美一站二站| 嫩草伊人久久精品少妇av杨幂| 欧美久久久久| 国产精品久久久久久亚洲毛片 | 99re8这里有精品热视频免费 | 日韩亚洲不卡在线| 亚洲免费网站| 久久综合激情| 亚洲人成人一区二区三区| 亚洲午夜久久久久久久久电影院| 欧美一区二视频在线免费观看| 久久久视频精品| 欧美日韩国产三级| 国产亚洲精品久久飘花| 亚洲人体影院| 欧美在线播放一区二区| 欧美本精品男人aⅴ天堂| 99视频精品全国免费| 新狼窝色av性久久久久久| 久久综合中文色婷婷| 欧美视频在线播放| 激情综合自拍| 亚洲自拍16p| 欧美黄在线观看| 亚洲欧美精品在线观看| 欧美成人精品一区二区| 国产欧美一区二区三区久久| 亚洲日韩视频| 久久精品中文字幕一区| 亚洲另类一区二区| 久久久久看片| 国产精品亚洲产品| 日韩亚洲综合在线| 久久婷婷国产综合精品青草| 99视频在线观看一区三区| 久久香蕉国产线看观看av| 国产精品理论片在线观看| 亚洲精品乱码久久久久久日本蜜臀 | 欧美在线欧美在线| 欧美日韩在线影院| 亚洲国产婷婷香蕉久久久久久99|