再次翻出算法导论,随机翻倒了随机排列数组这个部分,感觉数学是如此神奇!
首先,何谓随机排列数组。随机排列数组即通过排列给定的输入数组使数组元素的排列随机化,例如一个数组A[n],其中元素为的值为{1,2...,n},那么对数组进行随机排列,显然是有n!次不同的排列,并且每一次的排列都不一样。如何把数组元素排列随机化呢?
一个常用的方法就是为数组的每一个元素A[i]赋一个key,用来表示它的优先级,即P[i],并且[i]是随机的,然后根据这个优先级对数组中的元素进行排序。那么最终的数组即为一个随机排列数组。还是举个例子吧!
现在有数组A={2,3,1,4},并且它的随机优先级P={3,2,6,8}.根据优先级数组P,P[2]<P[1]<P[3]<P[4],那么最终的输出数组为A={3,2,1,4}。这个过程就是随机排列数组过程。该过程的伪代码为:
输入数组A[],长度为N:
for i=1 to N
生成随机数组P中元素P[i];
把P[i]当作A[i]的键值对数组A进行排序;
返回数组A
还有一个更好的办法是不需要借助优先数组,对数组元素进行原地排列。具体的方法是:
对于i从1到N,从元素A[i]到A[N]中随机选取一个元素与A[i进行交换。
它的伪代码为:
for i=1 to N
swap(A[i],A[random(i,N)];
返回数组A