Let `R` be the result array of size s
Let `I` be an input queue
> Fill the reservoir array
for j in the range [1,s]:
    R[j]=I.pop()
elements_seen=s
while I is not empty:
    elements_seen+=1
    j=random(1,elements_seen)       > This is inclusive
    if j<=s:
        R[j]=I.pop()
    else:
        I.pop()Let `R` by the result
Let `I` be an input queue
> Fill the reservoir array
R=I.pop()
elements_seen=1
while I is not empty:
    elements_seen+=1
    j=random(1,elements_seen) > This is inclusive
    if j<=s:
        R=I.pop()
    else:
        I.pop()int x;
int n = 3;
int rand_limit;
int rand_excess;
rand_excess = (RAND_MAX % n) + 1;
if (rand_excess == n)
    rand_excess = 0;
rand_limit = RAND_MAX - rand_excess;
while (x = rand() > rand_limit)
    ;
return x % n;od -A n -t d -N 1 /dev/urandom | sed -e 's/ \*//'
   -A n # do not output offset base
   -t d # output signed decimal
   -N <n> # Generate an n-byte number$ git branch <local branch name>
$ git remote add upstream <upstream repo>$ git fetch upstream
$ git checkout master
$ git merge upstream/master$ git push origin <local branch name>
$ git push origin masterUnder Settings → Branches change the default branch