3

我正在尝试编写一个程序,该程序从 0 到 9 获取 1000 个随机数,然后计算每个数字出现的次数:

    srand(time(NULL));
    multiset<int> M;//multiset that contains 1000 random numbers from 0 to 9
    for (int i = 0; i < 1000; i++){
        r.insert(rand() % 10);
        s.insert(rand() % 10);
    }

    vector <int> R(10);//vector that stores how many times each number appeared 
    //(so R[0] equals how many times 0 appeared and so on)

    pair<multiset<int>::iterator, multiset<int>::iterator> zero = M.equal_range(0);
    R[0] = zero.second - zero.first;

问题出在最后一行(我试图计算 0 出现的次数),它在减号下划线并表示没有运算符与这些操作数匹配。但为什么?隔间不是 zero.first 和 zero.second 端吗?以及如何解决?

编辑:我必须使用 multiset、vector 和 equal_range,这些是我老师选择的东西,而不是我。

4

2 回答 2

4

使用distance(zero.first, zero.second). 该-运算符不能应用于多集迭代器。

于 2017-12-18T21:12:57.577 回答
-1

使用地图会容易得多:

std::map<int, int> counts;
...
count[num]++; // map::operator[] will insert the value if it's not already in the sequence.
于 2017-12-18T21:05:48.370 回答