随机数

来源:互联网 发布:紧急域名升级通知访问 编辑:程序博客网 时间:2024/04/20 07:55
C#生成不重复随机数

  /// <summary>
  /// 功能描述:返回不重复随机数数组
  /// 作者:    杨艳峰
  /// 创建日期:2006-4-30
  /// </summary>
  /// <param name="Num">随机数个数</param>
  /// <param name="minNum">随机数下限</param>
  /// <param name="maxNum">随机数上限</param>
  /// <returns></returns>
  public int[] GetRandomArray(int Number,int minNum,int maxNum)
  {
   int j;
   int[] b=new int[Number];
   Random r=new Random();
   for(j=0;j<Number;j++)
   {
    int i=r.Next(minNum,maxNum+1);
    int num=0;
    for(int k=0;k<j;k++)
    {
     if(b[k]==i)
     {
      num=num+1;
     }
    }
    if(num==0 )
    {
     b[j]=i;
    }
    else
    {
     j=j-1;
    }
   }
   return b;
  }
  1. using System;   
  2. using System.Collections.Generic;   
  3. using System.Text;   
  4. using System.Collections;   
  5.   
  6. namespace 生成N个不重复随机数的两个函数   
  7. {   
  8.     class Program   
  9.     {   
  10.         static void Main(string[] args)   
  11.         {   
  12.             DateTime d1 = System.DateTime.Now;   
  13.             int[] list1 = GetRandom1(1, 100000, 5000);   
  14.             TimeSpan dd1 = System.DateTime.Now - d1;   
  15.   
  16.             DateTime d2 = System.DateTime.Now;   
  17.             int[] list2 = GetRandom2(1, 100000*100, 5000);   
  18.             TimeSpan dd2 = System.DateTime.Now - d2;   
  19.   
  20.             //foreach (int i in list1)   
  21.             //    Console.Write("{0},", i);   
  22.             //foreach (int ii in list2)   
  23.             //    Console.Write("{0},", ii);   
  24.   
  25.             Console.WriteLine("第一种方法,1-100000    里取5000个用时:{0}", dd1.TotalMilliseconds);   
  26.             Console.WriteLine("第二种方法,1-100000*100里取5000个用时:{0}", dd2.TotalMilliseconds);   
  27.   
  28.             Console.WriteLine("判断第二种方法里是否有重复数,如果是5000就是没有重复的:{0}",RemoveDup(list2).Length);   
  29.             Console.ReadKey();   
  30.   
  31.         }   
  32.   
  33.         public static int[] RemoveDup(int[] myData)   
  34.         {   
  35.             if (myData.Length > 0)   
  36.             {   
  37.                 Array.Sort(myData);   
  38.                 int size = 1;   
  39.                 for (int i = 1; i < myData.Length; i++)   
  40.                     if (myData[i] != myData[i - 1])   
  41.                         size++;   
  42.                 int[] myTempData = new int[size];   
  43.                 int j = 0;   
  44.                 myTempData[j++] = myData[0];   
  45.                 for (int i = 1; i < myData.Length; i++)   
  46.                     if (myData[i] != myData[i - 1])   
  47.                         myTempData[j++] = myData[i];   
  48.                 return myTempData;   
  49.             }   
  50.             return myData;   
  51.         }     
  52.   
  53.   
  54.         //方法1   
  55.         public static int[] GetRandom1(int minValue, int maxValue, int count)   
  56.         {   
  57.   
  58.             Random rnd = new Random();   
  59.             int length = maxValue - minValue + 1;   
  60.             byte[] keys = new byte[length];   
  61.             rnd.NextBytes(keys);   
  62.             int[] items = new int[length];   
  63.             for (int i = 0; i < length; i++)   
  64.             {   
  65.                 items[i] = i + minValue;   
  66.             }   
  67.             Array.Sort(keys, items);   
  68.             int[] result = new int[count];   
  69.             Array.Copy(items, result, count);   
  70.             return result;   
  71.   
  72.         }   
  73.   
  74.         //方法2   
  75.         public static int[] GetRandom2(int minValue, int maxValue, int count)   
  76.         {   
  77.             int[] intList = new int[maxValue];   
  78.             for (int i = 0; i < maxValue; i++)   
  79.             {   
  80.                 intList[i] = i + minValue;   
  81.             }   
  82.             int[] intRet = new int[count];   
  83.             int n = maxValue;   
  84.             Random rand = new Random();   
  85.             for (int i = 0; i < count; i++)   
  86.             {   
  87.                 int index = rand.Next(0, n);   
  88.                 intRet[i] = intList[index];   
  89.                 intList[index] = intList[--n];   
  90.             }   
  91.   
  92.             return intRet;   
  93.         }   
  94.   
  95.     }   
  96. }