1

私はクラップスのnゲームをシミュレートしようとしています。コードは私には理にかなっているようですが、正しい結果が得られません。たとえば、n = 5、つまり5ゲームを入れると、勝ち負けの合計は5より大きくなります。

これがどのように機能するかを示しています。最初のロールが2、3、または12の場合、プレーヤーは負けます。ロールが7または11の場合、プレーヤーが勝ちます。その他の最初のロールにより、プレーヤーは再びロールします。彼は7をロールするか、最初のロールの値になるまでロールを続けます。彼が7を出す前に初期値を再ロールした場合、それは勝利です。最初に7をロールすることは損失です。

from random import randrange

    def roll():
        dice = randrange(1,7) + randrange (1,7)
        return dice

    def sim_games(n):
        wins = losses = 0
        for i in range(n):
            if game():
                wins = wins + 1
            if not game():
                losses = losses + 1
        return wins, losses

    #simulate one game

    def game():

            dice = roll()
            if dice == 2 or dice == 3 or dice == 12:
                return False
            elif dice == 7 or dice == 11:
                return True
            else:
                dice1 = roll()
                while dice1 != 7 or dice1 != dice:
                    if dice1 == 7:
                        return False
                    elif dice1 == dice:
                        return True
                    else:
                        dice1 = roll()

    def main():

        n = eval(input("How many games of craps would you like to play? "))
        w, l = sim_games(n)

        print("wins:", w,"losses:", l)
4

5 に答える 5

5

問題は

        if game():
            wins = wins + 1
        if not game():
            losses = losses + 1

代わりに、

        if game():
            wins = wins + 1
        else:
            losses = losses + 1

コードでは、1 つではなく 2 つのゲームをシミュレートしています ( game()2 回呼び出して)。これにより、2 つ (勝敗) ではなく 4 つの可能な結果が得られ、全体的な結果に一貫性がなくなります。

于 2011-03-15T18:04:20.673 に答える
3

このコードでは

for i in range(n):
    if game():
        wins = wins + 1
    if not game():
        losses = losses + 1

2 回コールgame()するので、その場で 2 つのゲームをプレイします。あなたが欲しいのはelseブロックです:

for i in range(n):
    if game():
        wins = wins + 1
    else:
        losses = losses + 1

ところで、次の方法でロジックを簡素化できますin

def game():
    dice = roll()

    if dice in (2,3,12):
        return False

    if dice in (7,11):
        return True

    # keep rolling
    while True:
        new_roll = roll()

        # re-rolled the initial value => win
        if new_roll==dice:
            return True

        # rolled a 7 => loss
        if new_roll == 7:
            return False

        # neither won or lost, the while loop continues ..

コードは文字通りあなたが与えた説明です。

于 2011-03-15T18:05:07.017 に答える
1

これをしないでください

    for i in range(n):
        if game():
            wins = wins + 1
        if not game():
            losses = losses + 1

全然うまくいきません。

于 2011-03-15T18:13:00.533 に答える
0

オブジェクト指向の書き換え:

import random

try:
    rng = xrange   # Python 2.x
    inp = raw_input
except NameError:
    rng = range    # Python 3.x
    inp = input

def makeNSidedDie(n):
    _ri = random.randint
    return lambda: _ri(1,n)

class Craps(object):
    def __init__(self):
        super(Craps,self).__init__()
        self.die = makeNSidedDie(6)
        self.firstRes = (0, 0, self.lose, self.lose, 0, 0, 0, self.win, 0, 0, 0, self.win, self.lose)
        self.reset()

    def reset(self):
        self.wins   = 0
        self.losses = 0

    def win(self):
        self.wins += 1
        return True

    def lose(self):
        self.losses += 1
        return False

    def roll(self):
        return self.die() + self.die()

    def play(self):
        first = self.roll()
        res   = self.firstRes[first]
        if res:
            return res()
        else:
            while True:
                second = self.roll()
                if second==7:
                    return self.lose()
                elif second==first:
                    return self.win()

    def times(self, n):
        wins = sum(self.play() for i in rng(n))
        return wins, n-wins

def main():
    c = Craps()

    while True:
        n = int(inp("How many rounds of craps would you like to play? (0 to quit) "))
        if n:
            print("Won {0}, lost {1}".format(*(c.times(n))))
        else:
            break

    print("Total: {0} wins, {1} losses".format(c.wins, c.losses))

if __name__=="__main__":
    main()
于 2011-03-15T19:52:10.713 に答える
0

このコードには多くの問題があります。最も重要なことは、ループごとに game() を 2 回呼び出していることです。一度呼び出して結果を保存し、それに基づいて切り替える必要があります。

于 2011-03-15T18:05:16.040 に答える