• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
娃
博客园    首页    新随笔    联系   管理    订阅  订阅
模拟体育竞技分析
from random import random
def printInfo():
    print("我的学号后两位是:03何娃")
def getInputs():
    a = eval(input("请输入选手A的能力值(0-1): "))
    b = eval(input("请输入选手B的能力值(0-1): "))
    n = eval(input("模拟比赛的场次: "))
    return a, b, n
def simNGames(n, probA, probB):
    winsA, winsB = 0, 0
    for i in range(n):
        scoreA, scoreB = simOneGame(probA, probB)
        if scoreA > scoreB:
            winsA += 1
        else:
            winsB += 1
    return winsA, winsB
def gameOver(a,b):
    if a>=10 and b>=10:
         if abs(a-b)==2:
             return 1
    elif a<10 and b<10:
         if a==11 or b==11:
             return 1
    else:
         return 0
def simOneGame(probA,probB):
    scoreA,scoreB=0,0
    serving="A"
    while not gameOver(scoreA,scoreB):
         if serving=="A":
             if random()<probA:
                 scoreA+=1
             else:
                 serving="B"
         else:
             if random()<probB:
                 scoreB+=1
             else:
                 serving="A"
         return scoreA,scoreB
def printSummary(winsA,winsB):
     n=winsA+winsB
     print("选手A获胜{}场比赛,获胜的概率为{:0.1%}".format(winsA,winsA/n))
     print("选手B获胜{}场比赛,获胜的概率为{:0.1%}".format(winsB,winsB/n))
def main():
    printInfo()
    probA,probB,n=getInputs()
    winsA,winsB=simNGames(n,probA,probB)
    printSummary(winsA,winsB)
main()

  

posted on 2020-11-22 23:24  娃  阅读(121)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3