c++随机排序容器中的元素
作者:@apocelipes
本文为作者原创,转载请注明出处:https://www.cnblogs.com/apocelipes/p/10351335.html
在各种程序语言中都提供了将容器元素随机排序的shuffle
方法,c++也不例外。
不过c++将shuffle
放在了<algorithm>
中而不是像其他语言一样在random
里,同时c++17删除了原先的random_shuffle
新的程序应该使用c++11添加进去的std::shuffle
。其中一个好处是新的函数在可以自定义随机数生成方法的同时保证了更好的安全性。
先来看下新函数的原型:
template< class RandomIt, class URBG > void shuffle( RandomIt first, RandomIt last, URBG&& g );
其中first
和last
指定需要随机排序的范围,g
是一个“UniformRandomBitGenerator”,就是一个可以产生规定范围内的随机数的可调用对象。
所以g
可以是std::random_device
或者像std::default_random_engine
这样的随机数引擎,也可以是std::mt19937
这样的标准库提供的随机数生成器的对象,它们都在<random>
中。
shuffle
调用后目标容器内的元素排列顺序会被随机打乱,我们看个例子。
首先是两个帮助函数,避免做一些重复劳动:
// 帮助函数,打印vector的内容 template <typename T> std::ostream &operator<<(std::ostream &os, const std::vector<T> &v) { os << "{ "; for (const auto &i: v) { os << i << ", "; } os << "}"; return os; } // 帮助函数,生成一个符合UniformRandomBitGenerator要求的随机数生成器; // std::random_device虽然符合要求但是只适合于生成seed及安全要求较高的场合,因为速度可能很慢。 // 所以我们选择std::mt19937算法,你可以自己选择其他合适的算法 auto get_URBG() { std::random_device rd; // 使用random_device生成seed std::mt19937 g(rd()); return g; }
然后我们分别打乱一个std::vector<int>
和std::vector<std::string>
容器内元素的排列顺序:
// 随机排序容器内元素,打印随机排序前和随机排序后的容器内容 template <typename T> void shuffle_container(std::vector<T> &container) { std::cout << "before shuffle: " << container << std::endl; std::shuffle(container.begin(), container.end(), get_URBG()); std::cout << "after shuffle: " << container << std::endl; } int main() { std::vector<int> ivec{1,2,3,4,5}; shuffle_container(ivec); // 分割线 std::cout << std::string(40, '-') << std::endl; std::vector<std::string> svec{"a", "b", "c", "d", "e", "f", "g"}; shuffle_container(svec); }
我们编译写好的程序,然后运行:
可以看到元素都已经被随机排序了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端