이 기사는 주로 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!