我想更改map元素的值,如果它已经存在于map容器中,即计算该容器中元素的no
std :: map < int, int > m;
std :: map < int, int > :: iterator itr;
int arr[] = { 10, 40, 20, 20, 20, 20, 20, 20, 10, 30, 10, 30, 40 };
for (int i : arr) {
itr = m.find(i);
if (itr == m.end() ) {
int value = 0;
m.insert(std :: make_pair(i, value));
} else {
++itr->second;
}
}
itr = m.begin();
while (itr != m.end() ) {
std :: cout << itr->first << " -> " << itr->second << std :: endl;
++itr;
}
Run Code Online (Sandbox Code Playgroud)
输出错误:
10 -> 2
20 -> 5
30 -> 1
40 -> 1
Run Code Online (Sandbox Code Playgroud)
问题在于线路int value = 0;.自从您第一次遇到某个值以来,您遇到过一次,而不是零次.它应该是int value = 1;.
请注意,这for (int i : arr) { m[i] += 1; }将完成您的代码尝试执行的操作.与顺序容器相反,关联容器允许您访问容器中尚未存在的元素,如果缺少元素值,则初始化它们(零或默认初始化它们).
| 归档时间: |
|
| 查看次数: |
62 次 |
| 最近记录: |