如何从 C++ 容器中获取随机元素?

编程入门 行业动态 更新时间:2024-10-25 04:15:00
本文介绍了如何从 C++ 容器中获取随机元素?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

从 STL 范围中获取 [伪] 随机元素的好方法是什么?

What is a good way to get a [pseudo-]random element from an STL range?

我能想到的最好方法是做 std::random_shuffle(c.begin(), c.end()) 然后从 c.begin 中取出我的随机元素().

The best I can come up with is to do std::random_shuffle(c.begin(), c.end()) and then take my random element from c.begin().

但是,我可能想要一个来自 const 容器的随机元素,或者我可能不想要完全 shuffle 的成本.

However, I might want a random element from a const container, or I might not want the cost of a full shuffle.

有更好的方法吗?

推荐答案

我在 Google+ 的一篇文章中发布了这个解决方案,其他人引用了这个.把它贴在这里,因为这个比其他的稍微好一点,因为它通过使用 std::uniform_int_distribution 避免了偏见:

I posted this solution on a Google+ article where someone else referenced this. Posting it here, as this one is slightly better than others because it avoids bias by using std::uniform_int_distribution:

#include <random> #include <iterator> template<typename Iter, typename RandomGenerator> Iter select_randomly(Iter start, Iter end, RandomGenerator& g) { std::uniform_int_distribution<> dis(0, std::distance(start, end) - 1); std::advance(start, dis(g)); return start; } template<typename Iter> Iter select_randomly(Iter start, Iter end) { static std::random_device rd; static std::mt19937 gen(rd()); return select_randomly(start, end, gen); }

示例用途是:

#include <vector> using namespace std; vector<int> foo; /* .... */ int r = *select_randomly(foo.begin(), foo.end());

我最终创建了一个遵循类似方法并具有更好设计的要点.

更多推荐

如何从 C++ 容器中获取随机元素?

本文发布于:2023-11-29 00:20:04,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1644540.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:容器   元素

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!