実装方法:
最初に長さ n の配列を定義し、次に while ループを使用して乱数を生成し、配列に値を割り当てます。値を割り当てる前に、配列を走査する必要があります。既存の値が等しい場合、値を割り当てずに乱数を再生成し、定義されたすべての配列が割り当てられるまでループします。
例は次のとおりです:
/** * 功能:产生min-max中的n个不重复的随机数 * * min:产生随机数的其实位置 * mab:产生随机数的最大位置 * n: 所要产生多少个随机数 * */ public static int[] randomNumber(int min,int max,int n){ //判断是否已经达到索要输出随机数的个数 if(n>(max-min+1) || max <min){ return null; } int[] result = new int[n]; //用于存放结果的数组 int count = 0; while(count <n){ int num = (int)(Math.random()*(max-min))+min; boolean flag = true; for(int j=0;j<count;j++){ if(num == result[j]){ flag = false; break; } } if(flag){ result[count] = num; count++; } } return result; }
Java 学習ビデオの推奨:Java 開発入門
Set の特性を利用して、要素を繰り返すことはできません
/** * 功能:随机指定范围内N个不重复的数 * * @param min 指定范围最小值 * @param max 指定范围最大值 * @param n 随机数个数 */ public static int[] randomSet(int min, int max, int n) { Set<Integer> set = new HashSet<Integer>(); int[] array = new int[n]; for (; true;) { // 调用Math.random()方法 int num = (int) (Math.random() * (max - min)) + min; // 将不同的数存入HashSet中 set.add(num); // 如果存入的数小于指定生成的个数,则调用递归再生成剩余个数的随机数,如此循环,直到达到指定大小 if (set.size() >= n) { break; } } int i = 0; for (int a : set) { array[i] = a; i++; } return array; }
まず生成した乱数をセットに入れ、セットのサイズを決定します 必要な長さを超えていない場合はループを続行します 超えている場合はループを抜けて変換しますセットを配列に入れます。
その他の Java 関連記事の推奨事項: Java 言語の概要
以上がJavaで指定された間隔内でn個の異なる乱数を生成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。