码迷,mamicode.com
首页 > 其他好文 > 详细

STL 源码剖析 算法 stl_algo.h -- random_shuffle

时间:2014-07-20 23:12:29      阅读:231      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   os   io   

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie


random_shuffle

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


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


template <class RandomAccessIterator, class RandomNumberGenerator>
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<int> 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<int>(cout, " "));
}


STL 源码剖析 算法 stl_algo.h -- random_shuffle,布布扣,bubuko.com

STL 源码剖析 算法 stl_algo.h -- random_shuffle

标签:style   blog   http   color   os   io   

原文地址:http://blog.csdn.net/zhengsenlie/article/details/37994869

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!