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

yipeiwu_com4年前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 输出缓存详解

输出控制函数不对使用 header() 或 setcookie(), 发送的文件头信息产生影响,只对那些类似于 echo() 和 PHP 代码的数据块有作用。 我们先举一个简单的例子,让...

PHP排序算法类实例

本文实例讲述了PHP排序算法类。分享给大家供大家参考。具体如下: 四种排序算法的PHP实现: 1) 插入排序(Insertion Sort)的基本思想是: 每次将一个待排序的记录,按其...

简要剖析PHP的Yii框架的组件化机制的基本知识

简要剖析PHP的Yii框架的组件化机制的基本知识

组件是 Yii 应用的主要基石。是 yii\base\Component 类或其子类的实例。三个用以区分它和其它类的主要功能有: 属性(Property) 事件(Event)...

PHP5.4中json_encode中文转码的变化小结

在php5.4以前做json_encode的时候中文会被unicode编码,中文都会被编码,变成不可读的,类似“\u***”的格式,还会在一定程度上增加传输的数据量。 例如: 复制代码...

学习php设计模式 php实现桥梁模式(bridge)

学习php设计模式 php实现桥梁模式(bridge)

一、桥梁模式结构图   二、桥梁模式中主要角色 抽象化(Abstraction)角色:定义抽象类的接口并保存一个对实现化对象的引用。 修正抽象化(Refined Abstra...