monery8 发表于 2013-3-13 15:36

int类型数组中产生不重复的值(不重复随机数数组) c#

本帖最后由 monery8 于 2013-3-13 15:37 编辑


1、C# 如何产生100以内不重复的随机数
可以考虑先把这100个数放在一个数组内,每次随机取一个位置(第一次是1-100,第二次是1-99,...),将该位置的数与最后一个位置的数对调就可以了。
using System;
using System.Collections.Generic;
using System.Text;

namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
int [] arr=new int;
int i;
//初始化数组
for(i=1;i<=100;i++)
{
arr<i> = i;
}
//随机数
Random r = new Random();
for (int j = 100; j >= 1; j--)
{
int address = r.Next(1,j);
int tmp = arr;
arr = arr;
arr = tmp;
}
//输出
foreach (int k in arr)
{
Console.Write(k+" ");
}
}
}
}</i>
2、C#生成不重复随机数
/// <summary>
/// 功能描述:返回不重复随机数数组
   /// </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;
   Random r=new Random();
   for(j=0;j<Number;j++)
   {
    int i=r.Next(minNum,maxNum);
    int num=0;
    for(int k=0;k<j;k++)
    {
   if(b==i)
   {
      num=num+1;
   }
    }
    if(num==0 )
    {
   b=i;
    }
    else
    {
   j=j-1;
    }
   }
   return b;
}

zwluoqi 发表于 2013-3-14 14:49


感谢楼主的无私分享!{:soso__11402694654016840197_7:}

自力 发表于 2013-3-15 16:33

好强的逻辑,最怕这个了

skyangel 发表于 2013-4-1 10:01

和洗牌算法一样

batgreen 发表于 2013-4-26 21:26

就是乱序算法

借你的孤单 发表于 2017-3-20 07:58

很不错

crop_solid 发表于 2017-3-20 07:03

顶顶多好

王庆华 发表于 2017-3-20 07:50

真心顶

借你的孤单 发表于 2017-3-20 07:48

不错不错

king3200 发表于 2017-3-20 07:34

LZ真是人才
页: [1]
查看完整版本: int类型数组中产生不重复的值(不重复随机数数组) c#