分享

C#生成N个不重复随机数的两个函数

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

 

 


引用本页地址:http://www./item/CShengChengNGeBuZhongFuSuiJiShuDeLiangGeHanShu.html

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约