php取隨機數不重複的方法:1、使用【rand(min,max)】函數產生隨機數;2、使用【array_unique(arr)】對產生的陣列進行去重;3、利用索引快速的產生不重複的隨機數。
php取隨機數不重複的方法:
首先想到的是rand(min, max)
函數產生隨機數,實際上使用mt_rand(min,max)
能更加迅速的產生隨機數。
其次使用array_unique(arr)
對產生的陣列進行去重,實際上使用array_flip(array_flip(arr))
能更加快速的進行去重。
了解以上兩點我們便可以寫一個稍微優化過的函數:
/** * 生成指定长度不重复的字符串. * * @param integer $min 最小值. * @param integer $max 最大值. * @param integer $len 生成数组长度. * * @return array */ function uniqueRandom($min, $max, $len) { if ($min < 0 || $max < 0 || $len) { throw new LogicException('无效的参数'); } if ($max <= $min) { throw new LogicException('大小传入错误'); } $counter = 0; $result = array(); while ($counter < $len) { $result[] = mt_rand($min, $max); $result = array_flip(array_flip($result)); $counter = count($result); } shuffle($result); return $result; }
其實可以利用索引來更加快速的生成不重複的隨機數,且效率甩上面函數幾條街。
/** * 生成指定长度不重复的字符串. * * @param integer $min 最小值. * @param integer $max 最大值. * @param integer $len 生成数组长度. * * @return array */ function uniqueRandom2($min, $max, $len) { if ($min < 0 || $max < 0 || $len < 0) { throw new LogicException('无效的参数'); } if ($max <= $min) { throw new LogicException('大小传入错误'); } if (($max - $min + 2) < $len) { throw new LogicException("传入的范围不足以生成{$len}个不重复的随机数}"); } $index = array(); for ($i = $min; $i < $max + 1; $i++) { $index[$i] = $i; } $startOne = current($index); $endOne = end($index); for ($i = $startOne; $i < $endOne; $i++) { $one = mt_rand($i, $max); if ($index[$i] == $i) { $index[$i] = $index[$one]; $index[$one] = $i; } } return array_slice($index, 0, $len); }
此演算法與上面演算法相比巧妙之處在於:
對自增索引進行隨機,不會有重複的問題,避免了去重的開銷
用數組下標替代數組本身進行隨機,每取到一個隨機數字後就將其在取值範圍中排除,下一次只會在剩下的數字中取,一次遍歷就可以完成隨機數的選取。
相關學習推薦:PHP程式設計從入門到精通
以上是php如何取隨機數不重複?的詳細內容。更多資訊請關注PHP中文網其他相關文章!