溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java怎么實現(xiàn)生成n個不重復的隨機數(shù)

發(fā)布時間:2020-07-23 11:08:28 來源:億速云 閱讀:277 作者:小豬 欄目:編程語言

這篇文章主要講解了Java怎么實現(xiàn)生成n個不重復的隨機數(shù),內(nèi)容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

需求:

根據(jù)min和max,生成n個不重復的隨機數(shù)。(注:范圍[min,max],n <= (max - min +1))

思路:

0)、把從min到max的可能出現(xiàn)的數(shù)字全部放進一個候選List;
1)、隨機生成索引index(0 <= index <= (list.size()-1));
2)、根據(jù)index從List中取出一個數(shù),list.get(index),并移除這個元素;

代碼如下:

import java.util.ArrayList;
import java.util.List;
import java.util.Random;

public class MyRandom {

 /**
  * 根據(jù)min和max隨機生成一個范圍在[min,max]的隨機數(shù),包括min和max
  * @param min
  * @param max
  * @return int
  */
 public int getRandom(int min, int max){
  Random random = new Random();
  return random.nextInt( max - min + 1 ) + min;
 }

 /**
  * 根據(jù)min和max隨機生成count個不重復的隨機數(shù)組
  * @param min
  * @param max
  * @param count
  * @return int[]
  */
 public int[] getRandoms(int min, int max, int count){
  int[] randoms = new int[count];
  List<Integer> listRandom = new ArrayList<Integer>();

  if( count > ( max - min + 1 )){
   return null;
  }
  // 將所有的可能出現(xiàn)的數(shù)字放進候選list
  for(int i = min; i <= max; i++){
   listRandom.add(i);
  }
  // 從候選list中取出放入數(shù)組,已經(jīng)被選中的就從這個list中移除
  for(int i = 0; i < count; i++){
   int index = getRandom(0, listRandom.size()-1);
   randoms[i] = listRandom.get(index);
   listRandom.remove(index);
  }

  return randoms;
 }
}

小編再為大家分享一段:java產(chǎn)生10個不同隨機數(shù)的代碼:

package exercise03_jdknews;

import java.util.Random;
import java.util.Vector;

/**
 * 獲取10個1-20之間的隨機數(shù),要求不能重復
 * 
 * @author lgt
 *
 */
public class RandomNumberNoRepeat {
 public static void main(String[] args) {
  //創(chuàng)建一個產(chǎn)生隨機數(shù)的對象
  Random r = new Random();

  //創(chuàng)建一個存儲隨機數(shù)的集合
  Vector<Integer> v = new Vector<Integer>();

  //定義一個統(tǒng)計變量
  int count = 0;

  while(count < 10){
   int number = r.nextInt(20) + 1;

   //判斷number是否在集合中存在
   if(!v.contains(number)){
    //不在集合中,就添加
    v.add(number);
    count++;
   }
  }

  //遍歷輸出
  for(int i : v){
   System.out.println(i);
  }
 }
}

看完上述內(nèi)容,是不是對Java怎么實現(xiàn)生成n個不重復的隨機數(shù)有進一步的了解,如果還想學習更多內(nèi)容,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI