Generate Random Boggle Board
GolfScript, 116 bytes
Since the scoring is in bytes, I figure that means we can use all bytes in the solution. Going outside the printable ASCII set allows a somewhat shorter solution than Peter Taylor's, at the cost of making the code harder to display here. Without the unprintable data, my code looks like this:
'57 BYTES OF BINARY DATA HERE'256base 26base 6/{;9.?rand}${6rand=65+.81=' u '2/=}%8/n*
It's pretty similar to Peter Taylor's solution, and I admit to shamelessly borrowing bits of it (such as the .81=' u '2/=
trick), although I think I managed to shorten his shuffle slightly, even after spending an extra char byte for better randomness.
The binary string in the beginning of the script contains unprintable characters, and so cannot be directly pasted here. Instead, I'll provide the script as a hex dump:
0000000: 2701 8302 7c56 97d5 ec9c 52e3 462e 44d7 '...|V....R.F.D.
0000010: a8d2 81c9 6115 fc80 4da4 6cd3 b06f a6d8 ....a...M.l..o..
0000020: 4e7e 2029 12a9 f331 0b83 3481 de36 81e2 N~ )...1..4..6..
0000030: 41b4 534d dee8 13f7 ccfd 2732 3536 6261 A.SM......'256ba
0000040: 7365 2032 3662 6173 6520 362f 7b3b 392e se 26base 6/{;9.
0000050: 3f72 616e 647d 247b 3672 616e 643d 3635 ?rand}${6rand=65
0000060: 2b2e 3831 3d27 2020 7520 2732 2f3d 7d25 +.81=' u '2/=}%
0000070: 382f 6e2a 8/n*
On Linux, or any system with the xxd
utility installed, this hex dump can be turned back into a working 116-byte GolfScript program by passing it through xxd -r
.
Edit: Replaced 999rand
with 9.?rand
for much better randomness. The shuffle should now be about as close to perfect as the underlying RNG allows.
Python 2.7, 253 229 215 chars
from random import*
j=0
for x in map(choice,sample("AAEEGN ELRTTY AOOTTW ABBJOO EHRTVW CIMOTU DISTTY EIOSST DELRVY ACHOPS HIMNQU EEINSU EEGHNW AFFKPS HLNNRZ DEILRX".split(),16)):j+=1;print x+' u'[x=='Q']+'\n'[j%4:],
Most of the characters are just the dice themselves. I didnt want to spend too much time trying to reduce it too much
minor edit: removed 2 unnecessary bytes (extra spaces)
edit2: down to 229
edit3: down to 215
GolfScript (141 139 137 charsbytes)
Of which 94 expand to the string containing the dice. Figure doesn't include the unnecessary newline inserted to make it wrap so that the code can be seen without scrolling:
'Y
ISY
XIAOOW
VYAAEEGNABBJOOEHRTVWCIMOTUEIOSSTACHOPSHIMNQUEEINSUEEGHNWAFFKPSHLNNRZ'n/'TTELRD'*
6/{[6rand=99rand\]}%${1=.81=' u '2/=}%8/n*