时间:2021-05-19
核心代码
import java.util.Arrays;/** * 用Java产生100个1-150的数字 */public class RandomTest { public static void main(String[] args) { int[] resultArr = produceNum(1, 150, 100); for (Integer num : resultArr) { System.out.println(num); } System.out.println("+++++++++++++++++===================+++++++++++++"); // 对结果数组排序后再输出 Arrays.sort(resultArr); for (Integer num : resultArr) { System.out.println(num); } } /** * 产生随机数字 * @param minNum 最小数字 * @param maxNum 最大数字 * @param numCount 产生的数字个数 * @return 结果数组 */ public static int[] produceNum(int minNum, int maxNum, int numCount) { // 入参校验 // 如果随机数的个数大于产生随机数的范围;或最大数小于最小数 // 直接返回null,说明入参不符合要求 if (numCount > (maxNum - minNum + 1) || maxNum < minNum) { return null; } // 存放结果的数组 int[] resultArr = new int[numCount]; // count 记录已产生的随机数的个数 int count = 0; while(count < numCount) { // 产生随机数 int num = (int) (Math.random() * (maxNum - minNum)) + minNum; // flag 定义本次产生的随机数是否已在数组中 boolean flag = true; // 遍历数组中已产生的随机数 for (int i=0; i<count; i++) { // 同本次产生的随机数最比较 if (num == resultArr[i]) { // 如果已存在相同的值,则跳出for循环,继续外层的while循环,产生下一个随机数 flag = false; break; } } // 如果本次产生的随机数在数组中不存在,则将该随机数存放在数组中 if (flag) { resultArr[count] = num; // 数组中已产生的随机数个数加1 count++; } } return resultArr; }}代码解读
1 int num = (int) (Math.random() * (maxNum - minNum)) + minNum;
Math.random() 产生的是0~1 之间的double类型的随机数
Math.random() * 10 便会得到 0 ~ 10 之间的随机数,转int后便是0 ~ 9;如果给 Math.random() * 10 + 1,便是1 ~ 11 之间的随机数,转int便是1 ~ 10。
这里的1 相当于程序中的最小值,11则为最大值。
这样便得到了产生随机数的 (int) (Math.random() * (maxNum - minNum)) + minNum
2 for (int i=0; i<count; i++) {
由于每次产生的num都是随机的,所以无法保证重复的问题,所以只有通过去同已经产生的存在数组中的数字去比较,相同,则重新产生,不同,则添加进数组。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
复制代码代码如下://////生成不重复随机数列表实例//////不重复数数量///不重复数列表privatestaticListGetRandomList(i
以数字开头的重复数据如:复制代码代码如下:Array([0]=>100[k1]=>100[1]=>2123[k2]=>2123)该方法可以将以数字为key的值去
在此之前我使用Java的数组实现了产生N-M之间的不重复的随机数,下面是使用数列ArrayList实现同样的功能,代码如下:/***随机生成N--M,N个不重复
比如1233546548732这么多数字想取重复数据,并统计重复次数,可以用易语言编程来实现。1、易语言新建程序2、新建一个Windows窗口程序3、如下图所示
1.自己写代码产生随机的数字和字母组合,每产生1个去数据库查询该随机码是否已存在,如果已存在,则重新产生,直到不重复为止。优点:没发现有啥优点。缺点:产生速度慢