首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

PHP CodeBase: 生成N个不重复的随机数

但是我们这里讨论的是技术,就是需要生成1-25之间的16个不重复的随机数,去填补。具体怎么设计函数呢?将随机数存入数组,再在数组中去除重复的值,即可生成一定数量的不重复随机数。 程序如下: php /* * array unique_rand( int $min, int $max, int $num ) * 生成一定数量的不重复随机数 * $min 和 $max: 指定随机数的范围 *...> 程序运行如下: 2,3,4,6,7,8,9,10,11,12,13,16,20,21,22,24 补充几点说明: 生成随机数时用了 mt_rand() 函数。...这个函数生成随机数的平均速度要比 rand() 快四倍。 去除数组中的重复值时用了“翻翻法”,就是用 array_flip() 把数组的 key 和 value 交换两次。...返回数组前,先使用 shuffle() 为数组赋予新的键名,保证键名是 0-n 连续的数字。如果不进行此步骤,可能在删除重复值时造成键名不连续,给遍历带来麻烦。

1.4K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    如何生成不重复的随机数

    标签:Excel公式 有时候,我们想生成一系列随机数,但又不希望这些数字中有重复的数。 如果使用RANDBWEEN函数,如下图1所示,很可能会出现重复数。...图1 要想获取不重复的随机数,我们需要一点小技巧。例如,想要获取21个不重复的随机数,可以先将21个数字按顺序排序,然后再从中选择所需的数字,这样可以避免出现任何重复数。...步骤1:选择一列中包含21个单元格的区域。 步骤2:输入公式:=RAND(),然后按Ctrl+回车键,在所有选择的单元格中输入这个公式,如下图2所示。...找到最大值后,使用MATCH在列表中查找该值,其位置即为返回的不重复值。...图3 生成了21个不重复的随机数。 你还有其他获取不重复随机数的公式吗?

    60030

    生成不重复的随机数算法

    本文转载http://blog.csdn.net/zhoufoxcn/article/details/5825093#comments 有时我们需要从指定的数值范围内随机产生一个数,利用这个伪随机数去实现自己想要实现的东西...(Guid.NewGuid().GetHashCode()); int value = rand.next(intMin, intMax)代码实现,但程序员的最大 乐趣在于自己动脑,用不同的思路写出不同的算法...return result;         }         staticint[] GenerateNumber3()         {             // 用于存放1到33这33个数...                    index = random.Next(0, container.Length - i);                 //以随机生成的值作为索引取container...中的值                    value = container[index];                 //将随机取得值的放到结果集合中

    1.6K10

    PHP生成不重复的订单号

    使用场景:商城、微信支付等生成订单号需求 方法一 比较常见的一种简单方法 使用date()函数,获取当前日期的数字,再配合rand()函数,生成几位随机数。便是一个简单的12位订单号了 php function getOrderNum(){     $date = date('Ymd');     $rand = rand(0,9).rand(0,9).rand(0,9).rand(0,9...$rand; } echo getOrderNum(); uniqid()函数基于以微秒计的当前时间,生成一个唯一的 ID。...当时前面的7位是不会经常变动的(应该是秒数,一秒一次) 所以我们使用substr()函数,截取字符串,从第8位到13位,接着这里会有一个问题,得到的是数字+字母的随机数,如果你需要的订单号可以包含字母,...合适范围(5~12),最大12 这里是完全随机的字符。而且是基于时间微秒来生成的,重复的可能性非常非常低,之所以加上时间日期,是为了看起来更加统一。

    2.8K11

    C# Random 生成不重复随机数

    若要提高性能,请创建一个随时间推移能生成多个随机数的 Random 对象,而不要反复新建会生成同一个随机数的 Random 对象。...用 C# 生成不重复的随机数 我们可以使用两种方式初始化一个随机数发生器: 第一种方法不指定随机种子,系统自动选取当前时间作为随机种子: Random ro = new Random(); 第二种方法可以指定一个...不指定上下限的使用如下:  int iResult;  iResult=ro.Next(); 下面的代码指定返回小于100的随机数:  int iResult;  int iUp=100;  iResult...dResult;  dResult=ro.NextDouble(); 但是用Random类生成题号,会出现重复,特别是在数量较小的题目中要生成不重复的的题目是很难的。...0) {     hashtable.Add(nValue, nValue);     Console.WriteLine(nValue.ToString()); } } 方法3:递归,用它来检测生成的随机数是否有重复

    1.9K10

    C# Random 生成不重复随机数

    若要提高性能,请创建一个随时间推移能生成多个随机数的 Random 对象,而不要反复新建会生成同一个随机数的 Random 对象。...用 C# 生成不重复的随机数 我们可以使用两种方式初始化一个随机数发生器: 第一种方法不指定随机种子,系统自动选取当前时间作为随机种子: Random ro = new Random(); 第二种方法可以指定一个...不指定上下限的使用如下:  int iResult;  iResult=ro.Next(); 下面的代码指定返回小于100的随机数:  int iResult;  int iUp=100;  iResult...dResult;  dResult=ro.NextDouble(); 但是用Random类生成题号,会出现重复,特别是在数量较小的题目中要生成不重复的的题目是很难的。...0) {     hashtable.Add(nValue, nValue);     Console.WriteLine(nValue.ToString()); } } 方法3:递归,用它来检测生成的随机数是否有重复

    1.5K20

    PHP生成随机数(昵称随机生成器)

    php /** * @param int $type 1生成昵称,2生成姓名 * //汉语 - 给用户自动生成昵称 */ function nickname($type = 1){...醉熏的','潇洒的','糊涂的','积极的','冷酷的','深情的','粗暴的', '温柔的','可爱的','愉快的','义气的','认真的','威武的','帅气的','传统的','潇洒的...','漂亮的','自然的','专一的','听话的','昏睡的','狂野的','等待的','搞怪的', '幽默的','魁梧的','活泼的','开心的','高兴的','超帅的','留胡子的'...'英勇的','健忘的','故意的','无心的','土豪的','朴实的','兴奋的','幸福的','淡定的','不安的','阔达的','孤独的', '独特的','疯狂的','时尚的','落后的...'凶狠的','害怕的','重要的','危机的','欢喜的','欣慰的','满意的','跳跃的','诚心的','称心的','如意的','怡然的','娇气的','无奈的','无语的','激动的','愤怒的'

    6.1K30

    【说站】java每次生成不重复的随机数

    java每次生成不重复的随机数 本教程操作环境:windows7系统、java10版,DELL G3电脑。...1、方法说明 Math.random()返回值为[0.0,1.0)的double型数值,由于double型数的精度较高,可视为随机数,借助(int)进行类型转换,可获得整数随机数。...=100,min=1; int ran2 = (int) (Math.random()*(max-min)+min); System.out.println(ran2); } 有时候我们会需要一些随机生成的数字进行使用...,而这java种有着生成随机数字的方法。...本篇所带来的是Math.random()的方法,可以随机生成一些整数的随机数字。 以上就是java每次生成不重复随机数的方法,大家可以先就方法的使用进行了解,然后再动手尝试代码的操作。

    57340

    数组中重复的数

    之前有写过 找出数组中只出现一次的数,今天再来看下怎么找出数组中重复出现的数。 有一个长度为 n 的数组,所有的数字都在 0~n-1 的范围,现在要求找出数组中任意一个重复的数字。...思路二: 利用空间换时间的思想,新建一个哈希表,然后遍历数组,每扫描一个元素都去哈希表里查找是否也存在该元素,如果存在,即找到一个重复的数,如果不存在,则将该元素保存到哈希表。...如果 arr[i] 不等于 i,则继续拿 arr[i] 和 arr[arr[i]] 比较,如果 arr[i] 和 arr[arr[i]] 相等,则找到一个重复的数,因为该数字在 i 下标和 arr[i]...交换了之后,再重复上面的比较、交换操作,直到找到一个重复的数。 arr = [4,1,1,3,2,5,5] arr[0] != 0 则比较 arr[0] 和 arr[4] arr[0] !...= 0 则比较 arr[0] 和 arr[1] arr[0] == arr[1] 找到一个重复的数 你可能会问,为什么要交换,交换的目的就是为了把元素放到属于它的位置上,要让这个数组满足 arr[i]

    1.7K20

    PHP 生成时间种子 批量 随机数

    HP时间种子批量随机数。本文说明PHP如何用时间种子批量生成随机数。 PHP函数mt_rand()和rand()会在批量生成的时候是会有几率出现重复的随机数。...srand()和mt_srand()在PHP4.1开始已经不在显式调用了,在mt_rand和rand的时候会自动生成种子。因为,在批量随机的时候,我们自己显式条用生成种子,就可以避免重复。为什么呢?...php //存储生存的随机数 $randArr = array(); //生成十万个吧 for($i=0;$i<100000;$i++){ //生成种子 $date = explode(...' ', microtime()); $seed = $date[0]; //种子发生器 mt_srand($seed); //生成随机数 $randArr[]...> 随机数生成了。并且不会重复的哦。以时间为种子的好处就是省略了在普通的伪随机数会出现重复的情况时进行do{生成随机数code}while(!isset(新生成的一个随机数))的判断步骤。

    1.2K00

    PHP的加密伪随机数生成器的使用

    PHP的加密伪随机数生成器的使用 今天我们来介绍的是 PHP 中的加密伪随机数生成器(CSPRNG 扩展)。...随机数的生成其实非常简单,使用 rand() 或者 mt_rand() 函数就可以了,但是我们今天说的这个则是使用了更复杂算法的一套随机数生成器。...rand() 已经不是很推荐使用了,mt_rand() 的生成速度更快一些,也是现在的主流函数,而加密的伪随机数生成函数则是密码安全的,速度会比 mt_rand() 略慢一点。...它需要依赖操作系统的一些函数,这个我们后面再说。 这个加密扩展已经集成在 PHP7 中,不需要特别的安装,如果是 PHP7 以下的版本需要独立安装扩展。...如果在测试时找不到下面介绍的函数,请检查当前 PHP 的版本。

    1.2K30

    用GUID生成随机数(重复性基本为0)

    随机数不管是前端还是后端都会用到的一个地方,不管是从验证码还是各种生成的状态码,基本都是随机生成的,还有就是一些抽奖的算法,也是用随机数来处理的,生成随机数的方法目前是很多的,但是其实很多是重复性很大的...,今天简单的讲一下怎么生成随机数重复性很低的一种办法GUID(Globally Unique Identifier)一种由算法生成的二进制长度为128位的数字标识符 不重复的原理:GUID 的总数达到了...用于生成GUID的算法通常都加入了非随机的参数(如时间),以保证这种重复的情况不会发生。...不BB上代码: GUID的js: function GUID() { this.date = new Date(); /* 判断是否初始化过,如果初始化过以下代码,则以下代码将不再执行...格式,即8位数的时间,包括毫秒,毫秒为2位数:12300933 * 返回值:返回GUID日期格式的字条串 */ GUID.prototype.getGUIDTime

    2.7K30

    【组合数学】生成函数 ( 正整数拆分 | 重复有序拆分 | 不重复有序拆分 | 重复有序拆分方案数证明 )

    文章目录 一、重复有序拆分 二、不重复有序拆分 1、无序拆分基本模型 2、全排列 三、重复有序拆分方案数证明 参考博客 : 按照顺序看 【组合数学】生成函数 简要介绍 ( 生成函数定义 | 牛顿二项式系数...( 正整数拆分 | 正整数拆分基本模型 | 有限制条件的无序拆分 ) 一、重复有序拆分 ---- 将 正整数 N 重复地 , 有序拆分 成 r 部分 , 方案数为 C(N-1, r-1)..., 是 带系数 , 带限制条件的情况 , 参考 : 组合数学】生成函数 ( 使用生成函数求解不定方程解个数 ) 无序拆分的情况下 , 拆分后的正整数 , 允许重复 和 不允许重复 , 是两类组合问题..., 非全排列 k^r , \ \ r\leq n_i 可重复的元素 , 无序的选取 , 对应 多重集的组合 ; N= C(k + r - 1, r) 三、重复有序拆分方案数证明 ---- 使用一一对应的方法证明...: 将 正整数 N 重复地 , 有序拆分 成 r 部分 , 方案数为 C(N-1, r-1) ★ 拆分后的正整数 , 如果交换了次序之后 , 排列不同 , 其所代表的方案数也不同 ; 将该拆分转换成组合计数问题

    2.6K00

    【勘误】PHP的加密伪随机数生成器的使用

    原文章链接为:PHP的加密伪随机数生成器的使用 文中对于 random_bytes() 函数的描述有误。...不过由此带来的结果就是我们转换之后的十六进制的字符长度是我们设定的字符长度的 2 倍。这个函数的作用,可以为我们生成安全的用户密码 salt 、 密钥关键字 或者 初始化向量。...原错误内容:random_bytes() 每次调用都会生成不同内容的字符串,而参数则是字符长度的随机字符,在这里我们传递的是 5 ,返回了 10 个字符,可以看出这个参数是字符数量,而返回的其实是字节数量...或者我们就直接记住它返回的就是参数的两倍即可。至于这个函数的作用嘛,可以为我们生成安全的用户密码 salt 、 密钥关键字 或者 初始化向量。...Github原文链接: https://github.com/zhangyue0503/dev-blog/blob/master/php/202007/PHP的加密伪随机数生成器的使用.md

    1K10
    领券