日期:2014-05-20 浏览次数:20900 次
namespace Skyiv { using System.Collections.Generic; class Random : System.Random { private List<int> int32List = new List<int>(); public override int Next(int minValue, int maxValue) { if (minValue == maxValue) return minValue; int next = base.Next(minValue, maxValue); if (int32List.Count >= maxValue - minValue) return next; if (int32List.Contains(next)) return Next(minValue, maxValue); int32List.Add(next); return next; } } } namespace Test { using System; using Rand = Skyiv.Random; class Program { static void Main() { Rand r = new Rand(); Console.WriteLine(r.Next(21,25)); Console.WriteLine(r.Next(21,25)); Console.WriteLine(r.Next(21,25)); Console.WriteLine(r.Next(21,25)); Console.WriteLine(r.Next(21,25)); } } }
------解决方案--------------------
学习,收藏
------解决方案--------------------
@_@~
------解决方案--------------------
1: 把你最终需要的结果(不重复的数)预先放在一个数组中, 因为rand函数产生的随机数会重复,我们不直接用,而是用来对应数组的下标
2: rand产生一个随机下标,我们就取出对应数组中的值(我们真正需要的随机数)
3: 然后用数组最后一个值来替换该下标数组中的值
4: 将产生随机下标的范围减少一
5: goto 2
注: 3中所谓数组最后一个值是指产生随机下标范围内的最后一个.
如产生随机下标0-9, 第一次就用array[9]替换,第二次就用array[8]替换.
#include<time.h> #include<stdlib.h> #include <stdio.h> #define NUM 10 int main() { int cont[NUM]; int index, i; for (i=0; i<NUM; i++) cont[i] = i; srand((int)time(0)); for (i=0; i<NUM; i++) { index = (int)((float)(NUM-i) * rand() / (RAND_MAX+1.0)); printf("%d ", cont[index]); cont[index] = cont[NUM-1-i]; } putchar('\n'); return 0; }
------解决方案--------------------
路过,学习
------解决方案--------------------
^ō^ 先占一楼...
------解决方案--------------------
不懂C#,平时用EXCEL解决1~100的正整数随机排序时,使用下面的方法:
搞一个2维数组
第一维为随机数,第二维为等差序列
对该数组按照第一维排序,就得到第二维的随机顺序排列。