Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Write an algorithm in pseudocode for generating a sequence of pseudorandom numbers using a linear congruential generator.

Short Answer

Expert verified

Procedure congruence generator(m,c,a,x0: integers with m2,c0and x00)

i=1

whilexix0

xi+1:=(axi+c)modm

ii+1

Returnx0,x1,x2,x3,,xi

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

Step 1

We call the algorithm "congruence generator" and the input is four integers m(at least 2), c (nonnegative), a and x0(nonnegative).

procedure congruence generator: (m,c,a,x0integers with m32,c30and x030)

The variable will keep track of the iteration step. Initially we define I as 1. We also start by calculating x1.

i=1

x1:=(a0+c)modm

The algorithm needs to stop if we obtain a term that is equal to the initial termrole="math" localid="1668669191528" (xi=x0). In each iteration step, we need to execute role="math" localid="1668669107112" x1:=(a0+c)modm

While role="math" localid="1668669248816" xix0

role="math" localid="1668669305263" xi+1:=(axi+c)modmi:=i+1

Finally, we return the generate sequence

Returnx0,x1,x2,x3,,xi

02

Step 2

Combining all these steps, we then obtain the algorithm:

Procedure congruence generator(m,c,a,x0: integers withm2,c0and

i=1

localid="1668669783271" x1:=(a0+c)modm

While xix0

xi+1:=(axi+c)modmi:=i+1

Return x0,x1,x2,x3,,xi

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free