Author | rfw |
Submission date | 2011-05-22 08:09:33.472975 |
Rating | 6447 |
Matches played | 7503 |
Win rate | 66.95 |
Use rpsrunner.py to play unranked matches on your computer.
import random
from collections import defaultdict
ORDER = 6
class RPSEngine(object):
RPS = {
"R" : "P",
"P" : "S",
"S" : "R",
}
def __init__(self):
self.db = defaultdict(lambda: { "R" : 0, "P" : 0, "S" : 0 })
self.state = []
def learn(self, inp):
if len(self.state) == ORDER:
self.db[tuple(self.state)][inp] += 1
del self.state[0]
self.state.append(inp)
def decide(self):
if len(self.state) == ORDER:
possible = sorted(self.db[tuple(self.state)].iteritems(), key=lambda i: i[1], reverse=True)
if possible[0][1] == 0:
return random.choice(self.RPS.keys())
else:
return self.RPS[possible[0][0]]
else:
return random.choice(self.RPS.keys())
if input == "":
rpsengine = RPSEngine()
else:
rpsengine.learn(input)
output = rpsengine.decide()