php 생 성 중복 되 지 않 는 난수,배열 의 4 가지 방법 공유
<?php
define('RANDOM_MAX', 100);
define('COUNT', 10);
echo 'max random num: '.RANDOM_MAX, ' ;result count:'.COUNT, '<br/>';
invoke_entry('rand1');
invoke_entry('rand2');
invoke_entry('rand3');
invoke_entry('rand4');
function invoke_entry($func_name) {
$time = new time();
$time->time_start();
call_user_func($func_name);
echo $func_name.' time spend: ', $time->time_spend();
echo '<br/>';
}
function rand1() {
$numbers = range (1, RANDOM_MAX);
shuffle($numbers); //
$result = array_slice($numbers, 1, COUNT);
return $result;
}
function rand2() {
$result = array();
while(count($result)< COUNT) {
$result[] = mt_rand(1, RANDOM_MAX); //mt_rand() rand()
$result = array_unique($result); //
}
return $result;
}
function rand3() {
$result = array();
while(count($result) < COUNT) {
$_tmp = mt_rand(1, RANDOM_MAX);
if(!in_array($_tmp, $result)) { // ,
$result[] = $_tmp;
}
}
return $result;
}
function rand4() {
$result = array();
while (count($result) < COUNT) {
$result[] = mt_rand(1, RANDOM_MAX);
$result = array_flip(array_flip($result)); //array_flip key value
}
return $result;
}
class time {
private $_start;
public function time_start() {
$this->_start = $this->microtime_float();
}
public function time_spend() {
return $this->microtime_float() - $this->_start;
}
private function microtime_float() {
list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec);
}
}
?>
네 번 째 방법 은 뒤 집기 입 니 다.array 를 이용 하 세 요.flip()는 배열 의 키 와 값 을 뒤 집 고 phop 배열 특성 을 이용 하여 중복 되 는 키 를 덮어 씁 니 다.이때 다시 한 번 뒤 집 으 면 중복 되 는 값 을 제거 하 는 것 과 같 습 니 다.상기 몇 가지 방법 은 단지 간단 한 예 일 뿐,어떤 방법 은 적용 범위 가 제한 되 어 있다.
몇 가지 방법의 효율 을 살 펴 보 자.
array 로유 니 크()는 배열 이 클 때 성능 이 떨 어 지 므 로 물론 shuffle()도 이 영향 을 받는다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Laravel - 변환된 유효성 검사 규칙으로 API 요청 제공동적 콘텐츠를 위해 API를 통해 Laravel CMS에 연결하는 모바일 앱(또는 웹사이트) 구축을 고려하십시오. 이제 앱은 CMS에서 번역된 콘텐츠를 받을 것으로 예상되는 다국어 앱이 될 수 있습니다. 일반적으로 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.