怎么在php中生成一个不重复随机的数组-创新互联

今天就跟大家聊聊有关怎么在php中生成一个不重复随机的数组,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名注册、网络空间、营销软件、网站建设、张店网站维护、网站推广。

代码如下:



define('RANDOM_MAX', 100);
define('COUNT', 10);

echo 'max random num: '.RANDOM_MAX, ' ;result count:'.COUNT, '
';

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

在看看几种方法的效率:

怎么在php中生成一个不重复随机的数组

怎么在php中生成一个不重复随机的数组

看完上述内容,你们对怎么在php中生成一个不重复随机的数组有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。


网站栏目:怎么在php中生成一个不重复随机的数组-创新互联
当前网址:http://scjbc.cn/article/csiipj.html

其他资讯