Beefy Boxes and Bandwidth Generously Provided by pair Networks
The stupid question is the question not asked
 
PerlMonks  

markov (The Practice of Programming)

by powerman (Friar)
on Apr 23, 2002 at 10:17 UTC ( #161252=snippet: print w/replies, xml ) Need Help??
Description: Another cook book - "The Practice of Programming" by Kernighan and Pike. And again, realization of "Markov chains algorithm" on page 123 can and must be optimized! So clever C/C++/Java examples and so ugly Perl example... :-(
#
# variant from "The Practice of Programming"
#

#!/usr/bin/perl
$MAXGEN  = 10000;
$NONWORD = "\n";
$w1 = $w2 = $NONWORD;
while (<>) {
    foreach (split) {
    push(@{$statetab{$w1}{$w2}}, $_);
    ($w1, $w2) = ($w2, $_);
    }
}
push(@{$statetab{$w1}{$w2}}, $NONWORD);

$w1 = $w2 = $NONWORD;
for ($i=0; $i<$MAXGEN; $i++) {
    $suf = $statetab{$w1}{$w2};
    $r = int(rand @$suf);
    exit if (($t = $suf->[$r]) eq $NONWORD);
    print "$t\n";
    ($w1, $w2) = ($w2, $t);
}

#
# my variant
#

#!/usr/bin/perl -a0n
push @{$m{$F[$_-1]}{$F[$_]}}, $F[$_+1] for 1..$#F;
1 while defined($F[2+$i++] = splice @{$m{$F[0+$i]}{$F[1+$i]}},
    rand(@{$m{$F[0+$i]}{$F[1+$i]}}), 1);
print join(" ",@F[0..1+$i]),"\n";
Log In?
Username:
Password:

What's my password?
Create A New User
Node Status?
node history
Node Type: snippet [id://161252]
help
Chatterbox?
and all is quiet...

How do I use this? | Other CB clients
Other Users?
Others perusing the Monastery: (4)
As of 2016-12-08 00:56 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?
    On a regular basis, I'm most likely to spy upon:













    Results (133 votes). Check out past polls.