我的问题更多的是关于高山而不是编程语言,所以请随意使用任何语言来解释我。
我有一个数组,我想以一种随机的方式对它进行混洗,不管怎样,混洗必须同时涉及2个元素。所以,如果我有:
1 2 3 4 5 6 7 8 9 101-2,3-4,5-6等对必须混洗在一起,例如,导致以下结果
3 4 7 8 9 10 1 2 5 6发布于 2013-02-14 20:08:31
它与普通的随机数组相同,除了您将“随机数组”视为实际数组大小的一半。这意味着1,2,3,4,5,6实际上是一个数组1 2, 3 4, 5 6。
下面是一些使用fisher yates的伪代码
To shuffle an array a of n elements (indices 0..n-1) in pairs of 2:
for i from (n − 1) / 2 downto 1 do
j ← random integer with 0 ≤ j ≤ i
exchange a[j * 2] and a[i * 2]
exchange a[j * 2 + 1] and a[i * 2 + 1]发布于 2013-02-14 20:09:14
使用对的索引创建一个数组,即使用一个比输入数组小两倍的数组,在其上使用std::random_shuffle(在C++中),然后根据您的助手数组更改原始数组。
https://stackoverflow.com/questions/14874408
复制相似问题