fillit/tests/rand_test.py

46 lines
1.3 KiB
Python
Raw Normal View History

2024-12-26 00:57:09 +02:00
#!/usr/bin/env python
from __future__ import print_function
tet_shapes = [
'####\n....\n....\n....\n',
'#...\n#...\n#...\n#...\n',
'#...\n###.\n....\n....\n',
'##..\n#...\n#...\n....\n',
'###.\n..#.\n....\n....\n',
'.#..\n.#..\n##..\n....\n',
'..#.\n###.\n....\n....\n',
'#...\n#...\n##..\n....\n',
'###.\n#...\n....\n....\n',
'##..\n.#..\n.#..\n....\n',
'##..\n##..\n....\n....\n',
'.##.\n##..\n....\n....\n',
'#...\n##..\n.#..\n....\n',
'.#..\n###.\n....\n....\n',
'#...\n##..\n#...\n....\n',
'###.\n.#..\n....\n....\n',
'.#..\n##..\n.#..\n....\n',
'##..\n.##.\n....\n....\n',
'.#..\n##..\n#...\n....\n',
]
import argparse
import random
import os
parser = argparse.ArgumentParser(description="Generate random fillit problems")
parser.add_argument('count', metavar="count", type=int, default=10, nargs='?',
help="number of tetrominoes to output")
parser.add_argument('--seed', type=int, default=None,
help="mt_rand seed (to reproduce problems)")
args = parser.parse_args()
seed = args.seed
if seed is None:
seed = random.SystemRandom().randint(0, 2**19937-1)
random.seed(seed)
tets = [tet_shapes[random.randrange(len(tet_shapes))] for x in range(args.count)]
[print(x, end=("" if i == len(tets) - 1 else "\n")) for i, x in enumerate(tets)]