我无法弄清楚发生了什么。我收到关于我的第二个for循环的错误,这是循环遍历地图的错误。我想,这个简单的程序会找到数组中最常见的元素。
#include <iostream>
#include <map>
int mode(int* arr, int sz) {
std::map<int,int> M;
for (int i = 0; i < sz; i++) {
if (M.count(arr[i]) == 0) {
M[arr[i]] = 1;
} else {
M[arr[i]]++;
}
}
int largest = arr[0]
for (std::map<int,int>::iterator it = M.begin(); it != M.end(); it++) {
if (it->first > largest) {
largest = it->first;
}
}
return largest;
}
int main() {
int myArray[] = {1, 2, 5, 0, 10, 4, -4, 10, 69, 10, 4, 4, 4};
std::cout << "Mode = " << mode(myArray, sizeof(myArray)/sizeof(int));
return 0;
}
答案 0 :(得分:7)
你有一个缺少的分号';'
int largest = arr[0]
^
答案 1 :(得分:3)
你应该添加;在上一行的末尾:
int largest = arr[0];