PHP에서 반복되지 않는 난수를 생성하는 방법: 먼저 배열의 각 숫자에 아래 첨자 순서로 값을 할당한 다음 "[i, $num-1]" 범위에서 난수를 가져오기 시작합니다. 마지막으로 변경되지 않은 키에서 값 쌍에 대해 교대로 작업을 수행하면 됩니다.
권장: "PHP 비디오 튜토리얼"
PHP는 비반복 난수를 효율적으로 생성합니다.
PHP는 비반복 난수 배열 캡슐화 방법을 생성합니다
/* * array unique_rand( int $min, int $max, int $num ) * 生成一定数量的不重复随机数 * $min 和 $max: 指定随机数的范围 * $num: 指定生成数量 */ function unique_rand($min, $max, $num) { //初始化变量为0 $count = 0; //建一个新数组 $return = array(); while ($count < $num) { //在一定范围内随机生成一个数放入数组中 $return[] = mt_rand($min, $max); //去除数组中的重复值用了“翻翻法”,就是用array_flip()把数组的key和value交换两次。这种做法比用 array_unique() 快得多。 $return = array_flip(array_flip($return)); //将数组的数量存入变量count中 $count = count($return); } //为数组赋予新的键名 shuffle($return); return $return; }
이 방법은 다음과 같습니다. 난수를 배열에 저장한 다음 중복을 제거하는 것은... 비효율적입니다... 저는
PHP를 사용하여 n 범위(m
참고: "Programming Pearls"라는 책에는 제목이 "n(m
이 알고리즘은 매우 영리합니다. 난수를 취하는 대신 난수(배열의 첨자)의 위치를 취합니다. 난수를 얻을 때마다 숫자 자체를 값 범위에서 제외하고 다음 번에는 그 값만 얻습니다. 나머지 숫자에서 가져옵니다. 난수 선택은 한 번의 순회로 완료될 수 있으며 이는 매우 효율적입니다.
function rand_num($num='200'){ for($i=0;$i<$num;$i++){ $n[$i] = $i; } for($i=0;$i<$num;$i++){ $rand = mt_rand($i,$num-1); //数组 随机数交换下标 if($n[$i] == $i){ $n[$i] = $n[$rand]; $n[$rand] = $i; } } }
1. 첫 번째 단계는 배열의 각 숫자에 아래 첨자 순서로 값을 할당하여 해당 순서대로 배열된 $num 숫자 키 값의 배열을 얻는 것입니다.
2. 두 번째 단계에서는 [i, $num-1] 범위에서 난수 $rand를 얻기 시작하고, 얻은 난수 $rand를 현재 위치의 첨자에 해당하는 값 $rand로 사용합니다. 배열의 키 i를 배열의 $rand 키에 해당하는 첨자 값으로 바꿉니다. 이는 실제로 배열 키 값의 교차 교환입니다. 의미는 생성된 난수를 값 범위 [i,$num-1]에서 제외하고 다음 번에는 나머지 숫자 [i+1,num-1]에서 값을 가져오는 것입니다.
3. 세 번째 단계에서는 값의 반복을 피하기 위해 변경되지 않은 키-값 쌍에 대해서만 교번 연산을 수행합니다. 즉, 원래 배열이 순차적으로 배열된 위치에 대해 교번 연산을 수행합니다(키 == 값). .
4. 끝.
순차배열 부분 교환 과정
위 그림과 같이 10개의 난수 부분 예를 구합니다.
위 내용은 PHP에서 반복되지 않는 난수를 생성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!