This particular roadblock to completing the old assignment wasn't that difficult, but for some reason we weren't able to write a solution I felt comfortable with. In the end, the simplest thing to do would've been to randomly pick a permutation of a list. Python provides a shuffle function to do this.
from random import shuffle x = ['player t', 'player u', 'player v', 'player w', 'player x', 'player y', 'player z'] shuffle(x) print(x)
Some how we ended up wanting to do a more complicated system to order a list of players. It was about 5 years ago, but I believe the reason was to more faithfully simulate our interpretation of how the game assigned for homework was to be played.The decision was made to go through this sequence:
- Each player would roll a die.
- Ties result in another set of rolls to break the tie. But any higher values still count towards ranking ahead of lower values.
- For players who did not tie, their relative position would be determined by how high their roll was.
For example, we could have three players, X, Y, Z. If X and Y both rolled a 6 and Z rolled a 1, Z would be assigned the last spot and X and Y would roll again. If X got 5 and Y got 4 for their second rolls, the final order would be X, Y, Z. The follow diagram illustrates that example:
Looking back at it now, it seems to be like a tree expansion. Tree nodes would represent groups of players. For example, the root would be all unsorted players. Visiting the node would generate children by having each player roll their die. A child node of the root could be the players who tied the first round of rolls. Leaves would be players who did not tie. After all the nodes are expanded into leaves, an inorder traversal of the tree would result in the ranking.
from random import randint from itertools import groupby tree = [['player t', 'player u', 'player v', 'player w', 'player x', 'player y', 'player z']] nextGeneration = [] keepPlaying = True while keepPlaying: keepPlaying = False for node in tree: if len(node) == 1: nextGeneration.append(node) else: keepPlaying = True rolls = [randint(1,6) for i in range(len(node))] turn = sorted(zip(rolls,node), reverse=True) print 'players roll:', turn for key, group in groupby(turn, lambda x: x[0]): nextGeneration.append(list(i[1] for i in group)) tree = nextGeneration nextGeneration = [] print([item for sublist in tree for item in sublist])
If I recall correctly,this is what we wanted to do about 5 years ago in school. I don't see much use for it now though other than as an exercise in python. I need to think about how to test it more and make it more testable. A gui might help debug it and make what is happening clearer. At least I learned a little bit about groupby, sorted, zip, and list comprehensions.
1 comment:
I don't see a lot of stuff from school as being "real world" useful. YMMV *but* I will say that (when done right) it was meant to learn the foundation and hopefully get us familiar enough to "keep learning".
Perhaps I should be more harsh and try to get a flame war going?
Post a Comment