我想要一个数组中的随机数。
array like this int[] random={"1","2","3","4","5"};
我想随机取这些数字。它工作正常,但价值正在重复。我不会重复值。我想要随机数而不重复相同的数字。
我正在使用此代码获取随机数,
Random randomnumber=new Rambom();
int number= randomnumber.Next(random.Length());
如果有人知道告诉我这样做的想法,
谢谢。
我想要一个数组中的随机数。
array like this int[] random={"1","2","3","4","5"};
我想随机取这些数字。它工作正常,但价值正在重复。我不会重复值。我想要随机数而不重复相同的数字。
我正在使用此代码获取随机数,
Random randomnumber=new Rambom();
int number= randomnumber.Next(random.Length());
如果有人知道告诉我这样做的想法,
谢谢。
If the random array is the source of the numbers, you could remove the numbers as you get them, therefore removing the duplication altogether :-
List<int> random = new List<int>() { 1, 2, 3, 4, 5 };
private void MyButton_Click(object sender, RoutedEventArgs e)
{
Random randomnumber = new Random();
int number = random[randomnumber.Next(0, random.Count - 1)];
random.Remove(number);
MyList.Items.Add(number);
}
Paul Diston soultion 已经足够好,但数量越多效率低下。生成随机唯一数的一种简单方法是将它们添加到 HashSet。片段:
HashSet<int> hashSet = new HashSet<int>();
for (int i = 0; i < 10; i++)
{
hashSet.Add(rand.Next(5));
}
foreach (var item in hashSet.AsEnumerable()) //hashSet.ToList() to get list
{
Console.WriteLine(item);
}
稍后,如果您想要另一个带有随机数组的列表 - 随机播放。最好的方法之一是Fisher-Yates shuffle。片段:
public static void Shuffle<T> (Random rand, IList<int> list)
{
int n = list.Count;
while (n > 1)
{
int k = rand.Next(n--);
//swapping values
T temp = list[n];
list[n] = list[k];
list[k] = temp;
}
}
可悲的是,没有内置功能。
避免重复的有效方法是将找到的数字与数组的最后一个元素交换,然后将数组的大小减少 1。
循环遍历数组,看看您是否已经添加了数字。如果有,请创建新的随机数。然后再次检查。
我正在考虑从随机数组中删除已经选择的值。因此您可以在“随机数组”中搜索“数字”并将其删除。