Yuu*_*shi 22
std::map迭代器是双向的,这意味着选择一个随机密钥O(n).在不使用其他数据结构的情况下,基本上您唯一的选择是使用std::advance随机增量begin().例如:
std::map<K, V> m;
auto it = m.begin();
std::advance(it, rand() % m.size());
K random_key = it->first;
Run Code Online (Sandbox Code Playgroud)
(或者如果你有权访问,可以换掉rand()(例如)).std::mt19939<random>
| 归档时间: |
|
| 查看次数: |
7967 次 |
| 最近记录: |