如何防止PHP中产生重复随机数的方法

零到壹度
Lepaskan: 2023-03-23 14:08:01
asal
2030 orang telah melayarinya

本篇文章给大家分享的内容是如何防止PHP中产生重复随机数的方法,有着一定的参考价值,有需要的朋友可以参考一下

一、PHP内置函数实现不重复随机数

需求:要生成一个数组,这个数组里面有10个元素,都是整形,并且是1-60之间不重复的随机数。  
代码:

<?php   
    function get_randoms($min,$max,$num){  
       $count = 0;  
       $res = array();  
       while($count<$num){  
            $res[] = mt_random($min,$max);  
            $res = array_flip(array_flip($res));   
            $count = count($res);  
       }  
       return $res;  
    }  
$result = get_randoms(1,60,10);  
?>
Salin selepas log masuk

在这里 $count 表示结果数组的个数,他在while 循环中 使得结果数组的个数小于 目标个数。通过这样,获取到$count 是 目标个数 的一个数组。

期间,每一个循环中,通过mt_random($min,$max),随机出区间内的一个值,存放到数组$res中,然后通过两次key-value 交换,也就是通过数组key的唯一性,使得做到不重复。

二、不使用函数实现不重复随机数

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

代码示例:

<?php   function get_randoms($min,$max,$num){  
   $count = 0;  
   $res = array();  
   while($count<$num){  
       $key = mt_random($min,$max);  
       $res[$key] = $key;  
       $count = count($res);  
   }  
   return $res;  
}  
$result = get_randoms(1,60,10);  
?>
Salin selepas log masuk

这样完全是单独的通过数组key的唯一性  解决了这个问题。根本就不会用到array_flip。
总结:  
1,因为php提供了大量的内置函数,他们的执行效率都很高。在遇到问题的时候,尽可能去用它去解决问题。这样方便而且快速。

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

Atas ialah kandungan terperinci 如何防止PHP中产生重复随机数的方法. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!