php生成不重复随机数、数组的4种方法分享

yipeiwu_com6年前PHP代码库

下面写几种生成不重复随机数的方法,直接上代码吧

复制代码 代码如下:

<?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()将数组的键和值翻转,利用php数组特性,重复的键会覆盖,此时再翻转一次,就相同于去掉了重复的值。
以上几种方法只是简单的例子,有的方法适用范围有限。

在看看几种方法的效率:

用array_unique()在数组较大时性能比较差,当然shuffle()也会受此影响。

相关文章

关于php程序报date()警告的处理(date_default_timezone_set)

在写php程序中有时会出现这样的警告: PHP Warning: date(): It is not safe to rely on the system's timezone sett...

PHP中调用SVN命令更新网站方法

想说写一个通过网页就可以执行 SVN 升级的程序,结果并不是我想得那样简单,有一些眉角需要注意的说。 先以 Apache 的用户帐号执行 SVN checkout,这样 Apache 才...

PHP排序算法系列之插入排序详解

插入排序 有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,但要求插入后此数据序列仍然有序,这个时候就要用到一种新的排序方法——插入排序法,插入排序的基本操作就是将一个...

PHP的preg_match匹配字符串长度问题解决方法

项目中,用preg_match正则提取目标内容,死活有问题,代码测得死去活来。 后来怀疑PHP 的preg_match有字符串长度限制,果然,发现“pcre.backtrack_limi...

PHP线程的内存回收问题

当一个PHP线程结束时,当前占用的所有内存空间都会被销毁。那么如果这个线程不结束,怎么回收内存呢? refcount:引用技术器,可以理解为指向该个容器的指针个数吧。 is_ref:是否...