用的是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)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)