rand() and srand() in C++
rand() function is an inbuilt function in C++ STL, which is defined in header file <cstdlib>. rand() is used to generate a series of random numbers. The random number is generated by using an algorithm that gives a series of non-related numbers whenever this function is called.
The rand() function is used in C++ to generate random numbers in the range [0, RAND_MAX)
Note: If random numbers are generated with rand() without first calling srand(), your program will create the same sequence of numbers each time it runs.
rand() returns a pseudo-random number in the range of [0, RAND_MAX).
RAND_MAX: is a constant whose default value may vary between implementations but it is granted to be at least 32767.
Say if we are generating 5 random numbers in C++ with the help of rand() in a loop, then every time we compile and run the program our output must be the same sequence of numbers.
1804289383 846930886 1681692777 1714636915 1957747793
NOTE: This program will create same sequence of random numbers on every program run.
srand() function is an inbuilt function in C++ STL, which is a header file defined in <cstdlib>. srand() is used to initialize random number generators. The srand() function sets the starting point for producing a series of pseudo-random integers. If srand() is not called, the rand() seed is set as if srand(1) were called at the program start. Any other value for seed sets the generator to a different starting point.
void srand( unsigned seed ); OR int srand( unsigned int seed); Seeds the pseudo-random number generator used by rand() with the value seed.
seed: A seed for a new sequence of pseudo-random numbers to be returned by successive calls to rand()
This function returns a pseudo-generated random number.
Note: The pseudo-random number generator should only be seeded once, before any calls to rand(), and at the start of the program. It should not be repeatedly seeded or reseeded every time you wish to generate a new batch of pseudo-random numbers.
Standard practice is to use the result of a call to srand(time(0)) as the seed. However, time() returns a time_t value which varies every time and hence the pseudo-random number varies for every program call.
1326865685 1413967981 1967280748 919663823
NOTE: This program will create a different sequence of random numbers on every program run.
Time complexity: O(N) where N is the number of random numbers to be generated
How srand() and rand() are related to each other?
srand() sets the seed which is used by rand to generate “random” numbers. If you don’t call srand before your first call to rand, it’s as if you had called srand(1) to set the seed to one.
In short, srand() — Set Seed for rand() Function.
This article is contributed by Shivam Pradhan.