Anonymous user
Knuth's algorithm S: Difference between revisions
m
→{{header|REXX}}: changed indentation, added/changed comments, simplified two subroutines. -- ~~~~
(→{{header|REXX}}: added the REXX language. -- ~~~~) |
m (→{{header|REXX}}: changed indentation, added/changed comments, simplified two subroutines. -- ~~~~) |
||
Line 971:
=={{header|REXX}}==
<lang rexx>/*REXX program using Knuth's algorithm S (random sampling n of M items).*/▼
▲/*REXX program using Knuth's algorithm S (random sampling n of M items).*/
parse arg trials size . /*obtain the arguments from C.L. */
if trials=='' then trials=100000
if size=='' then size=3
#.=0 /*a couple handfuls of counters. */
call s_of_n_creator size /*create initial list of n items.*/
call
do
▲ _=!.count /*get a digit from the Nth item. */
#._=#._+1 /* ... and count it, of course. */▼
▲ end /*count*/
▲ end /*trials*/
▲say "Using Knuth's algorihm S for" comma(trials) 'trials, and with',
say
do dig=0 to 9 /*show & tell time for frequency.*/
say copies(' ',15) "frequency of the" dig 'digit is:' comma(#.dig)
end /*dig*/
/*──────────────────────────────────S_OF_N_CREATOR subroutine───────────*/
s_of_n_creator: parse arg item 1 items /*generate ITEM number of items*/
▲ end /*k*/
return /*out piddly work is done for now*/
/*──────────────────────────────────S_OF_N subroutine───────────────────*/
s_of_n: parse arg item; items=items+1 /*get "item", bump items counter.*/
c=random(1,items) /*should we replace a prev item? */
if c>size then return
_=random(1,size) /*now, figure out which previous */
!._=item /* ... item to replace with ITEM.
return /*and back to the caller we go. */
/*──────────────────────────────────COMMA subroutine────────────────────*/
comma: procedure; parse arg _,c,p,t;arg ,cu;c=word(c ",",1)
if cu=='BLANK' then c=' '; o=word(p 3,1); p=abs(o); t=word(t 999999999,1)
if \datatype(p,'W') | \datatype(t,'W') | p==0 | arg()>4 then return _
n=_'.9'; #=123456789; k=0;
e=length(_)-verify(reverse(_),' ')+1; end; else do; b=verify(n,#,"M")
do j=e to b by -p while k<t; _=
▲Output when using the default input of: <tt> 100000 2 </tt>
▲<pre style="height:35ex;overflow:scroll">
Using Knuth's algorihm S for 100,000 trials, and with size=3:
|