우리는 반복되는 난수를 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!