zoukankan      html  css  js  c++  java
  • C++ 字典 map详解

    C++ 字典 map详解

    2019-01-18 23:32:08 lh_lyh 阅读数 1123更多

    文章目录


    容器重要属性

    • 通过键值访问,而不是位置
    • 按Key有序排列
    • 键与值一 一对应
    • 键唯一,不存在相同的键对应不同的值

    操作

    • 迭代器

      1. begin 指向起始

      2. end 指向末尾

      3. rbegin 指向倒序起始(即末尾)

      4. rend 指向倒序末尾(即起始)

      // map::begin/end
      #include <iostream>
      #include <map>
      
      int main ()
      {
        std::map<char,int> mymap;
      
        mymap['b'] = 100;
        mymap['a'] = 200;
        mymap['c'] = 300;
      
        // show content:
        for (std::map<char,int>::iterator it=mymap.begin(); it!=mymap.end(); ++it)
          std::cout << it->first << " => " << it->second << '\n';
      
        return 0;
      }
      // Output:
      //	a => 200
      //	b => 100
      //	c => 300
      
    • 大小

      1. empty 判断容器是否为空

      // map::empty
      #include <iostream>
      #include <map>
      
      int main ()
      {
        std::map<char,int> mymap;
      
        mymap['a']=10;
        mymap['b']=20;
        mymap['c']=30;
      
        while (!mymap.empty())
        {
          std::cout << mymap.begin()->first << " => " << mymap.begin()->second << '\n';
          mymap.erase(mymap.begin());
        }
      
        return 0;
      }
      
      //Output:
      //a => 10
      //b => 20
      //c => 30
      

      2. size 返回容器大小

      // map::size
      #include <iostream>
      #include <map>
      
      int main ()
      {
        std::map<char,int> mymap;
        mymap['a']=101;
        mymap['b']=202;
        mymap['c']=302;
      
        std::cout << "mymap.size() is " << mymap.size() << '\n';
      
        return 0;
      }
      //Output:
      //mymap.size() is 3
      

      3. max_size 返回容器最大尺寸

    • 元素访问

      1. operater[ ]

      2. at

      // accessing mapped values: at / operator[]
      #include <iostream>
      #include <string>
      #include <map>
      
      int main ()
      {
       std::map<std::string,int> mymap = {
                     { "alpha", 0 },
                     { "beta", 0 },
                     { "gamma", 0 } };
      
       mymap.at("alpha") = 10;
       mymap["beta"] = 20;
       mymap.at("gamma") = 30;
      
       for (auto& x: mymap) {
         std::cout << x.first << ": " << x.second << '\n';
       }
      
       return 0;
      }
      //Output:
      //alpha: 10
      //beta: 20
      //gamma: 30
      
    • 修改元素

      1. insert 插入元素

      方法一:直接插入键值对mymap.insert ( std::pair<char,int>('a',100) );
      方法二:通过迭代器指定位置并插入std::map<char,int>::iterator it = mymap.begin(); mymap.insert (it, std::pair<char,int>('b',300)); // max efficiency inserting
      方法三:通过迭代器范围插入,区间半包含([ , ))
      std::map<char,int> anothermap; anothermap.insert(mymap.begin(),mymap.find('c'));

      // map::insert (C++98)
      #include <iostream>
      #include <map>
      
      int main ()
      {
       std::map<char,int> mymap;
      
       // first insert function version (single parameter):
       mymap.insert ( std::pair<char,int>('a',100) );
       mymap.insert ( std::pair<char,int>('z',200) );
      
       std::pair<std::map<char,int>::iterator,bool> ret;
       ret = mymap.insert ( std::pair<char,int>('z',500) );
       if (ret.second==false) {
         std::cout << "element 'z' already existed";
         std::cout << " with a value of " << ret.first->second << '\n';
       }
      
       // second insert function version (with hint position):
       std::map<char,int>::iterator it = mymap.begin();
       mymap.insert (it, std::pair<char,int>('b',300));  // max efficiency inserting
       mymap.insert (it, std::pair<char,int>('c',400));  // no max efficiency inserting
      
       // third insert function version (range insertion):
       std::map<char,int> anothermap;
       anothermap.insert(mymap.begin(),mymap.find('c'));
      
       // showing contents:
       std::cout << "mymap contains:\n";
       for (it=mymap.begin(); it!=mymap.end(); ++it)
         std::cout << it->first << " => " << it->second << '\n';
      
       std::cout << "anothermap contains:\n";
       for (it=anothermap.begin(); it!=anothermap.end(); ++it)
         std::cout << it->first << " => " << it->second << '\n';
      
       return 0;
      }
      //Output:
      //element 'z' already existed with a value of 200
      //mymap contains:
      //a => 100
      //b => 300
      //c => 400
      //z => 200
      //anothermap contains:
      //a => 100
      //b => 300
      

      2. erase 删除元素

      // erasing from map
      #include <iostream>
      #include <map>
      
      int main ()
      {
       std::map<char,int> mymap;
       std::map<char,int>::iterator it;
      
       // insert some values:
       mymap['a']=10;
       mymap['b']=20;
       mymap['c']=30;
       mymap['d']=40;
       mymap['e']=50;
       mymap['f']=60;
      
       it=mymap.find('b');
       mymap.erase (it);                   // erasing by iterator
      
       mymap.erase ('c');                  // erasing by key
      
       it=mymap.find ('e');
       mymap.erase ( it, mymap.end() );    // erasing by range
      
       // show content:
       for (it=mymap.begin(); it!=mymap.end(); ++it)
         std::cout << it->first << " => " << it->second << '\n';
      
       return 0;
      }
      //Output:
      //a => 10
      //d => 40
      

      3. swap 交换两个map容器内容

      // swap maps
      #include <iostream>
      #include <map>
      
      int main ()
      {
        std::map<char,int> foo,bar;
      
        foo['x']=100;
        foo['y']=200;
      
        bar['a']=11;
        bar['b']=22;
        bar['c']=33;
      
        foo.swap(bar);
      
        std::cout << "foo contains:\n";
        for (std::map<char,int>::iterator it=foo.begin(); it!=foo.end(); ++it)
          std::cout << it->first << " => " << it->second << '\n';
      
        std::cout << "bar contains:\n";
        for (std::map<char,int>::iterator it=bar.begin(); it!=bar.end(); ++it)
          std::cout << it->first << " => " << it->second << '\n';
      
        return 0;
      }
      //Output:
      //foo contains:
      //a => 11
      //b => 22
      //c => 33
      //bar contains:
      //x => 100
      //y => 200
      

      4. clear 清除容器

      5. emplace 构造并插入元素

      // map::emplace
      #include <iostream>
      #include <map>
      
      int main ()
      {
        std::map<char,int> mymap;
      
        mymap.emplace('x',100);
        mymap.emplace('y',200);
        mymap.emplace('z',100);
      
        std::cout << "mymap contains:";
        for (auto& x: mymap)
          std::cout << " [" << x.first << ':' << x.second << ']';
        std::cout << '\n';
      
        return 0;
      }
      //Output:
      //mymap contains: [x:100] [y:200] [z:100]
      
    • 操作

      1. 赋值

      // assignment operator with maps
      #include <iostream>
      #include <map>
      
      int main ()
      {
       std::map<char,int> first;
       std::map<char,int> second;
      
       first['x']=8;
       first['y']=16;
       first['z']=32;
      
       second=first;                // second now contains 3 ints
       first=std::map<char,int>();  // and first is now empty
      
       std::cout << "Size of first: " << first.size() << '\n';
       std::cout << "Size of second: " << second.size() << '\n';
       return 0;
      }
      //Output:
      //Size of first: 0
      //Size of second: 3
      

      2. find 获得指向元素的迭代器

      // map::find
      #include <iostream>
      #include <map>
      
      int main ()
      {
       std::map<char,int> mymap;
       std::map<char,int>::iterator it;
      
       mymap['a']=50;
       mymap['b']=100;
       mymap['c']=150;
       mymap['d']=200;
      
       it = mymap.find('b');
       if (it != mymap.end())
         mymap.erase (it);
      
       // print content:
       std::cout << "elements in mymap:" << '\n';
       std::cout << "a => " << mymap.find('a')->second << '\n';
       std::cout << "c => " << mymap.find('c')->second << '\n';
       std::cout << "d => " << mymap.find('d')->second << '\n';
      
       return 0;
      }
      //Output:
      //elements in mymap:
      //a => 50
      //c => 150
      //d => 200
      

      3. count 对某个键的元素计数

      // map::count
      #include <iostream>
      #include <map>
      
      int main ()
      {
        std::map<char,int> mymap;
        char c;
      
        mymap ['a']=101;
        mymap ['c']=202;
        mymap ['f']=303;
      
        for (c='a'; c<'h'; c++)
        {
          std::cout << c;
          if (mymap.count(c)>0)
            std::cout << " is an element of mymap.\n";
          else 
            std::cout << " is not an element of mymap.\n";
        }
      
        return 0;
      }
      //Output:
      //a is an element of mymap.
      //b is not an element of mymap.
      //c is an element of mymap.
      //d is not an element of mymap.
      //e is not an element of mymap.
      //f is an element of mymap.
      //g is not an element of mymap.
      

      4. lower_bound 返回下边界的迭代器

      返回指向该元素的迭代器

      5. upper_bound 返回上边界的迭代器

      返回指向该元素的下一个元素的迭代器

      // map::lower_bound/upper_bound
      #include <iostream>
      #include <map>
      
      int main ()
      {
       std::map<char,int> mymap;
       std::map<char,int>::iterator itlow,itup;
      
       mymap['a']=20;
       mymap['b']=40;
       mymap['c']=60;
       mymap['d']=80;
       mymap['e']=100;
      
       itlow=mymap.lower_bound ('b');  // itlow points to b
       itup=mymap.upper_bound ('d');   // itup points to e (not d!)
      
       mymap.erase(itlow,itup);        // erases [itlow,itup)
      
       // print content:
       for (std::map<char,int>::iterator it=mymap.begin(); it!=mymap.end(); ++it)
         std::cout << it->first << " => " << it->second << '\n';
      
       return 0;
      }
      //Output:
      //a => 20
      //e => 100
      

      6. equal_range 获得相同元素的范围

  • 相关阅读:
    Linux环境下入侵工具Knark的分析及防范 java程序员
    六个步骤即可防范ARP地址欺骗类病毒 java程序员
    巧用命令行 揪出ARP欺骗病毒母机方法 java程序员
    poj3264Balanced Lineup(线段树RMQ)
    有了1A的把握再去提交
    poj2828Buy Tickets(线段树 单点更新+区间求和+区间第K值)
    poj2513Colored Sticks(无向图判欧拉路、回路+trie树)
    ACM数学(转)
    sdut2381Broken Keyboard
    sdut2383Decode the Strings(循环节)
  • 原文地址:https://www.cnblogs.com/grj001/p/12223495.html
Copyright © 2011-2022 走看看