正好工作需要,需要一个方法能返回一组不重复的随机数,网上查了好多资料和实例。发现都是加时间种子的比较多。
最后自己想到了好办法。效率也高。100%不重复。
下面贴出代码:
/// <summary>
/// 返回一组不重复随机数生成方法-(完美,100%不重复)。
/// min 最小数,max 最大数,num 输出个数
/// 吴官迪 20160220
/// </summary>
/// <param name="min"></param>
/// <param name="max"></param>
/// <param name="num"></param>
/// <returns></returns>
public static List<int> GetNoRepeatRandom(int min, int max, int num)
{
//把数据先装进数组。
int[] yu = new int[max-min];
for (int i = 0; i < max - min; i++)
{
yu[i] =min+i;
}
//将要返回的随机数的数量。
List<int> list = new List<int>();
//安全性判断
if (num > yu.Length)
{
return list;
}
//这个一定要注意,不能放在循环内,会造成出来的随机数像排过序一样
Random ran = new Random();
for (int i = 0; i < num; i++)
{
//从数组中生成随机数
int intRan=ran.Next(yu.Length);
list.Add(yu[intRan]);
//把生成出来的随机数,从数组中去除。再次从数组中进行随机,就永远不会出现重复。
yu = yu.Where(p => p != yu[intRan]).ToArray();
}
return list;
}