Мне нужно сгенерировать 6 уникальных случайных чисел от 1 до 37; Сначала я использовал простое отображение массива:
private int k=6, n=37;
public int[] Results ()
{
// fill an array with numbers 1 2 3 . . . n
int[] numbers = new int[n];
for (int i = 0; i < numbers.length; i++)
numbers[i] = i + 1;
// draw k numbers and put them into a second array
int result[] = new int[k];
for (int i = 0; i < result.length; i++)
{
// make a random index between 0 and n - 1
int r = (int) (Math.random() * n);
// pick the element at the random location
result[i] = numbers[r];
// move the last element into the random location
numbers[r] = numbers[n - 1];
n--;
}
return result;
}
Проблема заключалась в том, что во многих случаях я получал почти равномерное распределение (особенно когда я делаю менее 10 тиражей), то есть: 1,9,16,18,24,30 или 5,16,18,22 26,29
Что мне действительно нужно, так это ИСТИННЫЙ рандомизатор, который может дать мне следующие результаты:
11,16,25,29,30,32 или 4,8,9,15,18,19 в МЕНЬШЕМ, а затем 10 ничьих.
Я видел также реализацию HashMap чего-то похожего:
import java.util.*;
public class RandomHash
{
HashMap numbers = new HashMap() ;
Random rnd_gen = new Random() ;
RandomHash()
{
for(;;)
{
int rnd_num = rnd_gen.nextInt() ;
Integer rnd_num_obj = new Integer(rnd_num) ;
if (! numbers.containsKey(rnd_num_obj) )
{
numbers.put(rnd_num_obj, rnd_num_obj) ;
/* Do whatever with the number */
break ;
} /* else loop and get another rnadom num */
} /*end for*/
}
}
Проблема в том, что в настоящее время я не знаю, как связать рандомизатор и хэш-карту с 6 и 32 соответственно. Будет ли хэш-карта давать более зашифрованные результаты?