使用std :: generate的随​​机unordered_multimap

时间:2019-01-30 13:02:52

标签: c++ c++17 stl-algorithm unordered-multimap

我正在尝试使用以下代码生成大小为10的随机unordered_multimap

#include <algorithm>
#include <unordered_map>
#include <cstdlib>

int main()
{
    auto m = std::unordered_multimap<int, int>(10);
    std::generate(
        m.begin(),
        m.end(),
        [](){return std::pair{std::rand(),std::rand()};}
    );
} 

但是不会编译错误

 In file included from /usr/include/c++/7/algorithm:62:0,
                 from main.cpp:2:
/usr/include/c++/7/bits/stl_algo.h: In instantiation of ‘void std::generate(_FIter, _FIter, _Generator) [with _FIter = std::__detail::_Node_iterator<std::pair<const int, int>, false, false>; _Generator = main()::<lambda()>]’:
<span class="error_line" onclick="ide.gotoLine('main.cpp',11)">main.cpp:11:5</span>:   required from here
/usr/include/c++/7/bits/stl_algo.h:4438:11: error: use of deleted function ‘std::pair<_T1, _T2>& std::pair<_T1, _T2>::operator=(typename std::conditional, std::is_copy_assignable<_T2> > >::value, const std::pair<_T1, _T2>&, const std::__nonesuch_no_braces&>::type) [with _T1 = const int; _T2 = int; typename std::conditional, std::is_copy_assignable<_T2> > >::value, const std::pair<_T1, _T2>&, const std::__nonesuch_no_braces&>::type = const std::pair&]’
  *__first = __gen();
  ~~~~~~~~~^~~~~~~~~
In file included from /usr/include/c++/7/utility:70:0,
                 from /usr/include/c++/7/unordered_map:38,
                 from main.cpp:1:
/usr/include/c++/7/bits/stl_pair.h:378:7: note: declared here
       operator=(typename conditional<
       ^~~~~~~~

Q :是否可以使用unordered_multimap生成随机的std::generate?如果没有,什么是最好的方法?

PS:我知道我应该使用std::default_random_engine而不是std::rand,而且我在实际代码中这样做,这只是出于说明目的。

2 个答案:

答案 0 :(得分:5)

您的代码不适用于地图。

来自documentation for std::generate

  

类型Ret必须使得可以解除引用类型ForwardIt的对象并为其分配值Ret

您无法分配地图项的键。容器“拥有”密钥。您只能分配映射的值。 This method of "setting each element" is simply unavailable for associative containers.

此外,您构造了unordered_multimap with bucket size 10, but no actual elements,因此您的范围始终为空(地图不是矢量!)。

您可以使用std::inserter进行此操作:

#include <algorithm>
#include <iterator>
#include <unordered_map>
#include <cstdlib>

int main()
{
    std::unordered_multimap<int, int> m;
    std::generate_n(
        std::inserter(m, m.begin()),
        10,
        [](){ return std::pair{std::rand(), std::rand()}; }
    );
}

...但是,老实说,只需循环执行此操作即可。 ;)

#include <unordered_map>
#include <cstdlib>

int main()
{
    std::unordered_multimap<int, int> m;
    for (size_t i = 0; i < 10; i++)
        m.emplace(std::rand(), std::rand());
}

每个人都可以阅读。

答案 1 :(得分:5)

您可以使用std::insert_iterator类模板来实现所需的内容:

auto m = std::unordered_multimap<int, int>{};

std::generate_n(std::insert_iterator(m, m.begin()),
     10, [](){ return std::pair{std::rand(),std::rand()}; });