PHP에서 반복되지 않는 난수를 얻는 방법: 먼저 "mt_random($min,$max)" 방법을 사용하여 간격 내에서 무작위로 값을 얻은 다음 두 개의 "키-값" 교환을 사용하여 비반복성을 얻습니다. 난수를 반복합니다.
권장: "PHP 비디오 튜토리얼"
PHP에서 반복되지 않는 난수를 생성하는 방법
PHP 내장 함수 반복되지 않는 난수
요구 사항: 배열을 생성하려면, 이 배열에는 10개의 요소가 있으며, 모두 정수이고 1에서 60 사이의 반복되지 않는 난수입니다.
코드:
코드 예:
<?php function get_randoms($min,$max,$num){ $count = 0; $res = array(); while($count<$num){ $res[] = mt_random($min,$max); $res = array_flip(array_flip($res)); $count = count($res); } return $res; } $result = get_randoms(1,60,10); ?>
여기서 그는 $count를 사용하여 결과 배열의 수를 가져오고 while 루프에서 결과 배열의 수를 목표 수보다 작게 만듭니다. 이를 통해 대상 번호의 배열인 $count를 얻습니다.
각 사이클 동안 mt_random($min,$max)을 통해 범위 내의 값을 무작위로 얻어서 $res 배열에 저장한 다음 두 번의 키-값 교환, 즉 배열 키 자연적으로 반복이 불가능합니다.
이 로직의 코드를 읽고 난 후, array_filp 함수를 모른다면 어떻게 하시겠습니까?
직설적으로 말하면, 난수가 중복되지 않도록 키의 고유성을 사용합니다. 그렇다면 이 문제를 단순화할 수 있을까요?
코드 예:
<?php function get_randoms($min,$max,$num){ $count = 0; $res = array(); while($count<$num){ $key = mt_random($min,$max); $res[$key] = $key; $count = count($res); } return $res; } $result = get_randoms(1,60,10); ?>
이것은 배열 키의 고유성을 통해 이 문제를 완전히 해결합니다. array_flip은 전혀 사용되지 않습니다.
요약:
1. PHP는 수많은 내장 함수를 제공하므로 실행 효율성이 매우 높습니다. 문제가 발생하면 이를 최대한 활용하여 문제를 해결하도록 노력하세요. 이것은 편리하고 빠릅니다.
2. PHP는 수많은 내장 함수를 제공하며 실행 효율성도 매우 높습니다. 그러나 효율성은 높지만 여전히 실행하는 데 시간이 걸립니다.
문제가 생겼을 때, 무턱대고 해결하지 말고, 먼저 해결책의 본질을 보고 능숙하게 실행하세요.
위 내용은 PHP에서 반복되지 않는 난수를 얻는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!