PHP efficiently generates a unique random number
PHP encapsulation method to generate a random array
/* * array unique_rand( int $min, int $max, int $num ) * 生成一定数量的不重复随机数 * $min 和 $max: 指定随机数的范围 * $num: 指定生成数量 */ function unique_rand($min, $max, $num) { //初始化变量为0 $count = 0; //建一个新数组 $return = array(); while ($count < $num) { //在一定范围内随机生成一个数放入数组中 $return[] = mt_rand($min, $max); //去除数组中的重复值用了“翻翻法”,就是用array_flip()把数组的key和value交换两次。这种做法比用 array_unique() 快得多。 $return = array_flip(array_flip($return)); //将数组的数量存入变量count中 $count = count($return); } //为数组赋予新的键名 shuffle($return); return $return; }
This method obtains random numbers each time and stores them in the array before deduplicating them... Inefficient... I don’t want to use
PHP is efficient Generate m non-repeating random numbers in the n range (m<=n)
Note: It is also mentioned in the book "Programming Pearls", titled "How to efficiently generate m n ranges" Non-repeating random numbers within (m<=n)"
This algorithm very cleverly takes the position of the random number (the subscript of the array), instead of taking the random number itself, each time After getting a random number, it will be excluded from the value range, and next time it will only be picked from the remaining numbers. The random number selection can be completed in one traversal, which is very efficient.
function rand_num($num='200'){ for($i=0;$i<$num;$i++){ $n[$i] = $i; } for($i=0;$i<$num;$i++){ $rand = mt_rand($i,$num-1); //数组 随机数交换下标 if($n[$i] == $i){ $n[$i] = $n[$rand]; $n[$rand] = $i; } } }
1. The first step is to assign a value to each number in the array in the order of its subscript, and obtain an array of $num numeric key values arranged in corresponding order.
2.The second step starts to take the random number $rand in the range [i, $num-1], and uses the obtained random number $rand as the current value in the array. The position key i corresponds to the subscript value $rand, and the value corresponding to the subscript of the key $rand in the array is replaced with i. This is actually a cross-exchange of array key values. The meaning is to exclude the generated random number from the value range [i,$num-1], and next time it will take the value from the remaining numbers [i 1,num-1].
3.The third step, in order to avoid repeated values, only perform alternating operations on the unchanged key-value pairs, that is, at the position where the original array is arranged sequentially (key == value) Perform alternating operations.
4.End.
As shown above, obtain 10 random number partial examples.
For more PHP related questions, please visit the PHP Chinese website: PHP Video Tutorial
The above is the detailed content of PHP efficiently generates a unique random number. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



How to use RANDBETWEEN to generate random numbers in Excel If you want to generate random numbers within a specific range, the RANDBETWEEN function is a quick and easy way to do it. This allows you to generate random integers between any two values of your choice. Generate random numbers in Excel using RANDBETWEEN: Click the cell where you want the first random number to appear. Type =RANDBETWEEN(1,500) replacing "1" with the lowest random number you want to generate and "500" with

How to optimize random number generation performance in Java development Random numbers are widely used in computer science, especially in cryptography, simulation, games and other fields. In Java development, we often need to generate random numbers to meet various needs. However, the performance of random number generation is often one of the concerns of developers. This article will explore how to optimize random number generation performance in Java development. ThreadLocalRandom class was introduced in Java7 using ThreadLocalRandom class

How to use PHP arrays to generate random numbers and verification codes Random numbers and verification codes are very common during the development of websites and applications. PHP provides various methods to generate random numbers and verification codes. This article will introduce how to use PHP arrays to generate random numbers and verification codes, with corresponding code examples. 1. Generate random numbers In PHP, we can use the rand() function to generate random numbers. The rand() function requires two parameters, the minimum value and the maximum value. The sample code is as follows: $min=1;$max=

Generate random numbers using Go language Go language is a modern, concise and efficient programming language that provides many built-in libraries for generating random numbers. Among them, the crypto/rand package provides a series of functions to generate secure random numbers. In this article, we will generate random numbers by using the Read function from the crypto/rand package. First, we need to import the crypto/rand package and create a byte array to store the random numbers. The code example is as follows: packagemain

Explore the method and application of NumPy to generate random numbers. Introduction: Random numbers are widely used in computer science and statistics, such as simulation experiments, data generation and feature selection. In Python, the NumPy (NumericalPython) library is a powerful numerical computing library that provides many functions for generating random numbers. This article will explore the random number generation method in NumPy and give specific code examples. 1. NumPy’s random number generation function provided by NumPy

How to use Random.nextInt() method to generate random numbers in Java? Random numbers are widely used in computer science and can be used to generate passwords, random events in games, random sampling in data science, etc. Java provides the Random class to generate random numbers, and the nextInt() method can be used to generate a random integer. Below I will introduce how to use the Random.nextInt() method to generate random numbers and provide specific code examples. First, we need

How to avoid generating duplicate random numbers in Golang: Create a new random number generator rand.New(rand.Source). Use rand.NewSource(time.Now().UnixNano()) as the entropy source. Use rand.Intn(n) to generate random integers.

Using Java's Math.random() function to generate random numbers. Random numbers are a very common concept in computer programming and can help us implement various functions, such as generating random passwords, lottery draws, random events in games, etc. In Java, we can use Math.random() function to generate random numbers. The Math.random() function is a static method in the Java standard library. It returns a random double type number greater than or equal to 0 and less than 1. pass
