This program has been disqualified.
Author | dllu |
Submission date | 2011-07-08 21:18:45.414989 |
Rating | 7363 |
Matches played | 1596 |
Win rate | 76.69 |
#see also www.dllu.net/rps.html
import random
numPre = 60
numMeta = 18
if not input:
limits = [42,19,10]
beat={'R':'P','P':'S','S':'R'}
moves=['','','']
pScore=[[3]*numPre,[3]*numPre,[3]*numPre,[3]*numPre,[3]*numPre,[3]*numPre]
centrifuge={'RP':'a','PS':'b','SR':'c','PR':'d','SP':'e','RS':'f','RR':'g','PP':'h','SS':'i'}
length=0
p=[random.choice("RPS")]*numPre
m=[random.choice("RPS")]*numMeta
mScore=[3]*numMeta
helicase=[0,0,0,0,0,0]
else:
for i in range(numPre):
pScore[0][i]=0.8*pScore[0][i]+((input==p[i])-(input==beat[beat[p[i]]]))*3
pScore[1][i]=0.8*pScore[1][i]+((output==p[i])-(output==beat[beat[p[i]]]))*3
pScore[2][i]=0.87*pScore[2][i]+(input==p[i])*3.3-(input==beat[p[i]])*0.9-(input==beat[beat[p[i]]])*3
pScore[3][i]=0.87*pScore[3][i]+(output==p[i])*3.3-(output==beat[p[i]])*0.9-(output==beat[beat[p[i]]])*3
pScore[4][i]=(pScore[4][i]+(input==p[i])*3)*(1-(input==beat[beat[p[i]]]))
pScore[5][i]=(pScore[5][i]+(output==p[i])*3)*(1-(output==beat[beat[p[i]]]))
for i in range(numMeta):
mScore[i]=(mScore[i]+(input==m[i]))*(1-(input==beat[beat[m[i]]]))
moves[0]+=centrifuge[input+output]
moves[1]+=input
moves[2]+=output
length+=1
for z in range(3):
limit = min([length,limits[z]])
j=length+1
for y in range(3):
if j>limit:
j=limit
while j>=1 and not moves[y][length-j:length] in moves[y][0:length-1]:
j-=1
i = moves[y].rfind(moves[y][length-j:length],0,length-1)
p[0+2*y+6*z] = moves[1][j+i]
p[1+2*y+6*z] = beat[moves[2][j+i]]
helicase[0] = helicase[0]*0.95+{'R':0,'P':-0.1,'S':0.1}[output]
helicase[1] = helicase[1]*0.95+{'R':0.1,'P':0,'S':-0.1}[output]
helicase[2] = helicase[2]*0.95+{'R':-0.1,'P':0.1,'S':0}[output]
p[18] = {0:'R',1:'P',2:'S',3:'R',4:'P',5:'S'}[helicase.index(max(helicase[0:3]))]
helicase[3] = helicase[3]*0.95+{'R':0.1,'P':0,'S':-0.1}[input]
helicase[4] = helicase[4]*0.95+{'R':-0.1,'P':0.1,'S':0}[input]
helicase[5] = helicase[5]*0.95+{'R':0,'P':-0.1,'S':0.1}[input]
p[19] = {0:'R',1:'P',2:'S',3:'R',4:'P',5:'S'}[helicase.index(max(helicase[3:6]))]
for i in range(20,20*3):
p[i]=beat[beat[p[i-20]]]
for i in range(0,6,2):
m[i]= p[pScore[i ].index(max(pScore[i ]))]
m[i+1]=beat[p[pScore[i+1].index(max(pScore[i+1]))]]
for i in range(6,18):
m[i]=beat[beat[m[i-6]]]
output = beat[m[mScore.index(max(mScore))]]
if random.random<0.13 or random.randint(3,40)>length:
output=beat[random.choice("RPS")]