Author | dllu |
Submission date | 2011-06-02 18:17:14.133285 |
Rating | 7157 |
Matches played | 6377 |
Win rate | 72.89 |
Use rpsrunner.py to play unranked matches on your computer.
#RNA Polymerase
#This enzyme helps with RNA replication, so that the two resultant strands
#are RNA_strand1 and RNA_strand2 respectively.
import random
if not input:
RNA_strand1=""
RNA_strand2=""
output = random.choice(['R','P','S'])
ribonuclease = {'RP':'I','PS':'A','SR':'M','PR':'S','SP':'U','RS':'P','RR':'E','PP':'R','SS':'B'}
else:
j=6
RNA_strand1+=input
RNA_strand2+=ribonuclease[input+output]
length = len(RNA_strand2)
if j>length:
j=length
i = RNA_strand2.rfind(RNA_strand2[length-j:length-1],0,length-2)
while not RNA_strand2[length-j:length-1] in RNA_strand2[0:length-2]:
j-=1
i = RNA_strand2.rfind(RNA_strand2[length-j:length-1],0,length-2)
if j<2:
break
if i==-1 or j+i>=length or random.random() < 0.142857142857:
output = random.choice(['R','P','S'])
else:
output = {'R':'P', 'P':'S', 'S':'R'}[RNA_strand1[j+i]]