> 백엔드 개발 > PHP 튜토리얼 > PHP에서 반복되지 않는 난수를 생성하는 방법 분석

PHP에서 반복되지 않는 난수를 생성하는 방법 분석

WBOY
풀어 주다: 2016-07-25 08:52:52
원래의
1034명이 탐색했습니다.
  1. function get_randoms($min,$max,$num){
  2. $count = 0;
  3. $res = array();
  4. while($count<$num){
  5. $res[] = mt_random($min,$max);
  6. $res = array_flip(array_flip($res));
  7. $count = count($res);
  8. }
  9. return $res;
  10. }
  11. $result = get_randoms(1,60,10);
  12. ?>
复制代码

在这里 他用$count 结果数组的个数,他在while 循环中 使得结果数组的个数小于 目标个数。通过这样,获取到$count 是 目标个数 的一个数组。(bbs.it-home.org 脚本学堂) 期间,每一个循环中,通过mt_random($min,$max),随机出区间内的一个值,存放到数组$res中,然后通过两次key-value 交换,也就是通过数组key的唯一性,使得做到不重复。

我看了这个逻辑的代码之后,我不禁陷入了深思,假如说当你不知道array_filp 函数的时候你怎么做? 说白了就是用key的唯一性,使得随机数不会存在重复。那么我们能不能将这个问题简单化处理呢?

代码:

  1. function get_randoms($min,$max,$num){
  2. $count = 0;
  3. $res = array();
  4. while($count<$num){
  5. $key = mt_random($min,$max);
  6. $res[$key] = $key;
  7. $count = count($res);
  8. }
  9. return $res;
  10. }
  11. $result = get_randoms(1,60,10);
  12. ?>
复制代码

这样完全是单独的通过数组key的唯一性 解决了这个问题。根本就不会用到array_flip。

总结: 1,因为php提供了大量的内置函数,他们的执行效率都很高。(bbs.it-home.org 程序员之家) 在遇到问题的时候,尽可能去用它去解决问题。这样方便而且快速。

2,php 提供了大量的内置函数,执行效率也很高,但是,虽然效率高,还是需要时间去执行的。 在遇到问题的时候,不要盲目的去做,可以先看清处理方法的本质,以便于巧妙的实现他。



원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿