怎么用insert函数给map容器添加元素?

怎么用insert函数给map容器添加元素?,第1张

用的是c++ map的insert方法。

函数定义:

single element (1)  插入单个元素 队尾插入

pair<iterator,bool>insert (const value_type&val)

with hint (2)  插入单个元素 在position的位置插入

iterator insert (iterator position, const value_type&val)

range (3)  插入一串元素 一般用的是另一个map中的,从开始到结束

template <class InputIterator> void insert (InputIterator first, InputIterator last)

示例:

// map::insert (C++98)

#include <iostream>

#include <map>

int main ()

{

  std::map<char,int> mymap

  // first insert function version (single parameter):第1种

  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):第2种

  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):第3种

  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

}

 

首先包含头文件

#include <string>

#include <map>

using namespace std

如下写法均合法:

map<string, int>word_count

word_count["string_1"] = 1

word_count.insert(make_pair<string, int>("string_2", 2))

word_count.insert(map<string, int>::value_type("string_3", 3))

在Visual Studio 2010中编译通过。

insert返回一个pair

即ret是一个pair,

他的first是迭代器,他的位置是给定关键字元素的位置,

second是bool值 ret.second你加的是bool,应该不行的。

你的测试时怎么成功的,应该不行啊。

输入1 2 1 2 1

现在的map是 (1, 3)(2, 2)

输入2

ret返回pair(2的迭代器,bool)

ret.first(2的迭代器)->second(value++)

(1,3)(2,3)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11941942.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存