>  기사  >  Java  >  Java에서 고유 난수를 얻는 방법

Java에서 고유 난수를 얻는 방법

王林
王林원래의
2019-11-12 11:46:012374검색

Java에서 고유 난수를 얻는 방법

우리는 반복되는 난수를 Random random = new  Random()

에서 얻을 수 있다는 것을 알고 있습니다. 따라서 1에서 33 사이의 6개 숫자를 얻고 싶다고 가정해 보겠습니다. 반복되지 않는 난수를 만드는 방법은 무엇입니까?

예:

//首先定义一个数字数组存储1到33
int[ ]  redBall = new int[33[;
for(int i = 0;i<redBall.length;i++){
  redBall[i] = i+1;
}
int[ ]  redNumber = new int[6];     //存储六个随机数的实际数组
int index = -1;                             //通过随机数字数组下标获取随机数
for(int i = 0;i<redNumber.length;i++){
  index = random.nextInt(redBall.length-i);   //每次获取数字数组长度-i的随机数,比如第一次循环为33第二次为32,
  redNumber[i] = redBall[index];                   //把数字数组随机下标的值赋给实际数组
  int temp = redBall[index];                           //定义一个变量暂存下标为index时的值
  redBall[index] = redBall[redBall.length-1-i];  //把下标为index的值与数组下标最后的值交换
  redBall[redBall.length-1-i] = temp;             //交换后,下次循环把数字数组最后的值去掉,从而实现不重复
}

추천 튜토리얼: JavaTutorial

위 내용은 Java에서 고유 난수를 얻는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.