randomShuffle
Diggory
diggsey at googlemail.com
Mon Jun 3 04:29:07 PDT 2013
On Monday, 3 June 2013 at 10:10:15 UTC, Yann wrote:
> Thanks a lot for the suggestions!
>
> Cheers,
> Yann
>
> On Monday, 3 June 2013 at 10:06:30 UTC, bearophile wrote:
>> Yann:
>>
>>> Is there a better way to accomplish this? Naively, I would
>>> expect something like
>>> "return iota(1, 1000).randomShuffle.take(10).sort;"
>>
>> Two ways, the first gives items in random order, the second
>> ordered as you seem to desire:
>>
>> import std.stdio, std.random, std.range, std.array;
>> void main() {
>> iota(1, 1001).randomCover(rndGen).take(10).writeln;
>> iota(1, 1001).randomSample(10).writeln;
>> }
>>
>>
>> But be careful with randomCover, because maybe it takes the
>> rnd generator by value.
>>
>> Bye,
>> bearophile
For small samples from very large ranges an efficient algorithm
would be:
int[] randomGen(int N, int M) {
if (N == 0)
return [];
int[] result = randomGen(N-1, M-1);
int num = rand(M);
foreach (ref int i; result)
if (i >= num)
++i;
result ~= num;
return result;
}
More information about the Digitalmars-d-learn
mailing list