有关c# 随机函数的实例详解

发布时间:2019-07-26编辑:脚本学堂
本文介绍下,有关c#中随机函数的一些例子,供大家学习参考。

先来看一个c#随机函数的例子。
 

复制代码 代码示例:
private static char[] constant =
{
'0','1','2','3','4','5','6','7','8','9',
'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z',
'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'
};
public static string GenerateRandomNumber(int Length)
{
System.Text.StringBuilder newRandom = new System.Text.StringBuilder(62);
Random rd = new Random();
for (int i = 0; i < Length; i++)
{
newRandom.Append(constant[rd.Next(62)]);
}
return newRandom.ToString();
}

如何在一段数字区间内随机生成若干个互不相同的随机数,比如在从1到20间随机生成6个互不相同的整数,并通过此文介绍Visual c#中随机数的用法。

.net.Frameword中提供了一个专门产生随机数的类System.Random,此类默认情况下已被导入,编程过程中可以直接使用。
计算机并不能产生完全随机的数字,它生成的数字被称为伪随机数,它是以相同的概率从一组有限的数字中选取的,所选的数字并不具有完全的随机性,但就实用而言,其随机程度已经足够了。

可以用以下两种方法初始化一个随机数发生器;
函数是这样用,比如100至999的随机数
 

复制代码 代码示例:
Random ran=new Random();
int RandKey=ran.Next(100,999);
 

这样会有重复,可以给Random一个系统时间做为参数,以此产生随机数,就不会重复了。

方法1,不指定随机种子,系统自动选取当前时前作随机种子:
 

复制代码 代码示例:
Random ra=new Random();

方法2,指定一个int型的参数作为随机种子:
 

复制代码 代码示例:
int iSeed=6;
Random ra=new Random(iSeed);

妆下来,用到Random.Next()方法产生随机数。
 

复制代码 代码示例:
ra.Next();

它返回一个大于或等于零而小于2,147,483,647的数。

下面介绍它的重载函数和其它一些方法。
 

复制代码 代码示例:
publicvirtualint Next(int);
用法:ra.next(20)

返回一个小于所指定最大值(此处为20)的正随机数。
 

复制代码 代码示例:
publicvirtualint Next(int minValue, int maxValue);
用法:ra.next(1,20)
 

返回一个指定范围内(此处为1-20之间)的随机数,我们在下面的实例中会用到此函数。

类System.Random还有几个方法。

公共方法:
NextBytes用随机数填充指定字节数组的元素。
NextDouble返回一个介于 0.0 和 1.0 之间的随机数。

受保护的方法:
Sample返回一个介于 0.0 和 1.0 之间的随机数,只允许子类对象访问。

来看具体的实例吧。
要在一段数字区间内随机生成若干个互不相同的随机数,比如在从1到20间随机生成6个互不相同的整数。
主要是下面两个函数getRandomNum与getNum:
 

复制代码 代码示例:
publicint[] getRandomNum(int num,int minValue,int maxValue)
{
Random ra=new Random(unchecked((int)DateTime.Now.Ticks));
int[] arrNum=newint[num];
int tmp=0;
for (int i=0;i<=num-1;i ){
tmp=ra.Next(minValue,maxValue); //随机取数
arrNum[i]=getNum(arrNum,tmp,minValue,maxValue,ra); //取出值赋到数组中
}
return arrNum;
}

getRandomNum即是在区间[minValue,maxValue]取出num个互不相同的随机数,返回的数组包含着结果。
其中随机数是这样创建的 Random ra=new Random(unchecked((int)DateTime.Now.Ticks));为什么不用Random ra=new Random();(系统自动选取当前时前作随机种子)呢?

用系统时间做随机种子并不保险,如果应用程序在一个较快的计算机上运行,则该计算机的系统时钟可能没有时间在此构造函数的调用之间进行更改,Random 的不同实例的种子值可能相同。这种情况下,就需要另外的算法来保证产生的数字的随机性。

为了保证产生的随机数足够"随机",不得不使用复杂一点的方法来获得随机种子。

在上面的这段程序中,首先使用系统时间作为随机种子,然后将上一次产生的随机数跟循环变量和一个与系统时间有关的整型参数相乘,以之作为随机种子,从而得到了每次都不同的随机种子,保证了产生足够"随机"的随机数。

函数getNum是一递归,用它来检测生成的随机数是否有重复,如果取出来的数字和已取得的数字有重复就重新随机获取。

注意:要用一同一个随机数实例生成,所以ra要作为参数传入getNum中,否则生成的数字会有重复。
 

复制代码 代码示例:

publicint getNum(int[] arrNum,int tmp,int minValue,int maxValue,Random ra){
int n=0;
while (n<=arrNum.Length-1)
{
if (arrNum[n]==tmp) //利用循环判断是否有重复
{
tmp=ra.Next(minValue,maxValue); //重新随机获取。
getNum(arrNum,tmp,minValue,maxValue,ra);//递归:如果取出来的数字和已取得的数字有重复就重新随机获取。
}

}
return tmp;
}

把随机数显示出来,当点击一个button时取出的数字显示在一个label中。
 

复制代码 代码示例:
private void button1_Click(object sender, System.EventArgs e)
{
int[] arr=getRandomNum(6,1,20); //从1至20中取出6个互不相同的随机数
int i=0;
string temp="";
while (i<=arr.Length-1){
temp =arr[i].ToString() "";
i ;
}
label1.Text=temp; //显示在label1中
}