博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
STL 源代码剖析 算法 stl_algo.h -- random_shuffle
阅读量:6306 次
发布时间:2019-06-22

本文共 1433 字,大约阅读时间需要 4 分钟。

本文为senlie原创,转载请保留此地址:

random_shuffle

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------

描写叙述:将[first,last)的元素次序随机重排。
思路:
必须是 RandomAccessIterator 
1.遍历区间
2.产生[0,i)中的一个随机数rand。将*(first+rand)与i交换
??怎么证明随机性 
源代码:
template 
inline void random_shuffle(RandomAccessIterator first, RandomAccessIterator last) { __random_shuffle(first, last, distance_type(first));}template
void random_shuffle(RandomAccessIterator first, RandomAccessIterator last, RandomNumberGenerator& rand) { //这里必须是传引用。

由于随机数产生器有局部状态。每次被调用都会改变 if (first == last) return; for (RandomAccessIterator i = first + 1; i != last; ++i) iter_swap(i, first + rand((i - first) + 1)); } template <class RandomAccessIterator, class Distance> void __random_shuffle(RandomAccessIterator first, RandomAccessIterator last, Distance*) { if (first == last) return; for (RandomAccessIterator i = first + 1; i != last; ++i) #ifdef __STL_NO_DRAND48 iter_swap(i, first + Distance(rand() % ((i - first) + 1))); #else iter_swap(i, first + Distance(lrand48() % ((i - first) + 1))); #endif }

演示样例:
int main(){	vector
vec; for(int ix = 0; ix < 10; ix++) vec.push_back(ix); random_shuffle(vec.begin(), vec.end()); copy(vec.begin(), vec.end(), ostream_iterator
(cout, " "));}
你可能感兴趣的文章
数据库设计技巧
查看>>
css定位概述
查看>>
C# 动态修改配置文件 (二)
查看>>
BOM:文档对象模型 --树模型
查看>>
我的Android进阶之旅------>WindowManager.LayoutParams介绍
查看>>
segment
查看>>
获取鼠标的原始移动值
查看>>
Linux信号 编程
查看>>
有关滚动与位置
查看>>
Box2D自定义重力
查看>>
chpasswd
查看>>
mysqldump --single-transaction 和--lock-tables参数详解
查看>>
android 数据库_sql语句总结
查看>>
python购物车
查看>>
解决python2和python3的pip冲突
查看>>
面试/编程
查看>>
linux每日命令(16):head命令
查看>>
公司内部分享【富有成效的每日站会】总结
查看>>
打造一个上传图片到图床利器的插件(Mac版 开源)
查看>>
iOS横竖屏
查看>>