zoukankan      html  css  js  c++  java
  • python之预测体育竞技分析

    1.采取排球比赛规则

    2.规则介绍:前四局采用二十五分制,每个队只有赢得二十五分,并同时超过二分时,才胜一局,正式比赛采用五局三胜制,决胜局采取15分制,一人先得8分后,两队交换场区,按原位置顺序继续比赛到结束。在决胜局(第五局)之比赛先获15分并领先两分为胜。

    3.插入代码

    # -*- encoding:utf-8 -*-
    '''
    模拟排球竞技
    @author: LuDuo
    '''
    # 比赛规则:
    # 1. 采用5局3胜制
    # 2. 前四局采用25分制,每个队只有在赢得至少25分,且同时超过对方2分时才胜一局
    # 3. 决胜局(第五局)采用15分制,先获得15分,且同时超过对方2分为胜
    
    from random import random
    from time import time
    def printInfo():
        '''
        function: 打印程序的介绍信息
        '''
        print("{:*^70}".format("产品简介"))
        print("产品名称: 排球竞技模拟分析器")
        print("产品概述: 通过输入2个队伍A和B的能力值(0到1之间的小数表示),能够模拟多次2个队伍A和B的排球竞技比赛,从而得出各自的胜率!")
        print("产品作者: 陆光朵 - 36")
        print("{:*^70}".format("模拟开始"))
    
    def getInputs():
        '''
        function: 获得用户输入的参数
        '''
        probA = eval(input("请输入队伍A的能力值(0~1):"))
        probB = eval(input("请输入队伍B的能力值(0~1):"))
        n = eval(input("请输入需要模拟比赛的场次数:"))
        return probA, probB, n
    
    def printResult(n, winsA, winsB):
        '''
        function: 输出模拟比赛的结果
        '''
        print("{:*^70}".format("模拟结束"))
        print("竞技分析开始,共模拟{}场比赛。".format(n))
        print(">>>队伍A获胜{}场比赛,占比{:0.1%}".format(winsA,winsA/n))
        print(">>>队伍B获胜{}场比赛,占比{:0.1%}".format(winsB,winsB/n))
    
    def simNGames(n, probA, probB):
        '''
        function: 模拟n场比赛
        n: 模拟n场比赛
        probA, probB: 分别为队伍A和B的能力值
        winA, winB: 队伍A和B在一场比赛中获胜的局数
        winsA, winsB: 队伍A和B赢得比赛的场数,总共n场
        '''
        winsA, winsB = 0, 0
        for _ in range(n):
            winA, winB = simOneGame(probA, probB)
            if winA > winB:
                winsA += 1
            else:
                winsB += 1
        return winsA, winsB
    
    def simOneGame(probA, probB):
        '''
        function: 模拟一场比赛,包括五局,采取五局三胜制
        probA, probB: 分别为队伍A和B的能力值
        return: 返回队伍A和B在本场比赛中获胜的局数
        scoreA, scoreB: 分别为队伍A和B一局比赛获得的分数
        winA, winB: 分别为队伍A和B一场比赛获胜的局数
        N: 代表本次比赛的局次
        '''
        winA, winB = 0, 0
        for N in range(5):
            scoreA, scoreB = simAGame(N, probA, probB)
            if scoreA > scoreB:
                winA += 1
            else:
                winB += 1
            if winA == 3 or winB == 3:
                break
        return winA, winB
    
    def simAGame(N, probA, probB):
        '''
        function: 模拟一局比赛
        N: 代表本次比赛的局次
        probA, probB: 分别为队伍A和B的能力值
        return: 返回队伍A和B在本局比赛中获得的分数
        '''
        scoreA, scoreB = 0, 0    # 分别为队伍A和B一局比赛获得的分数
        serving = 'A'            # 发球方
        while not GameOver(N, scoreA, scoreB):
            if serving == 'A':
                if random() > probA:
                    scoreB += 1
                    serving = 'B'
                else:
                    scoreA += 1
            else:
                if random() > probB:
                    scoreA += 1
                    serving = 'A'
                else:
                    scoreB += 1
        return scoreA, scoreB
    
    def GameOver(N, scoreA, scoreB):
        '''
        function: 定义一局比赛的结束条件
        N: 代表当前局次(第五局为决胜局)
        return: 若比赛结束的条件成立返回真,否则为假
        '''
        if N <= 4:
            return (scoreA>=25 and scoreB>=25 and abs(scoreA-scoreB)>=2)
        else:
            return (scoreA>=15 and abs(scoreA-scoreB)>=2) or (scoreB>=15 and abs(scoreA-scoreB)>=2)
    
    if __name__ == "__main__":
        printInfo()
        probA, probB, n = getInputs()
        Time = time()
        winsA, winsB = simNGames(n, probA, probB)
        print("模拟用时: {:.1f}s".format(time()-Time))
        printResult(n, winsA, winsB)

    运行结果:

    谢谢。

  • 相关阅读:
    对象属性编辑器中实现像Size,Rectangle等可以展开的属性
    远程办公产品风口会不会把SOHO自由职业吹起来
    项目加
    推荐几款免费又好用的项目管理工具
    Sprint Retrospective
    敏捷管理的大概背景和Scrum的特性
    推荐几款最好用的项目管理系统,即好用又免费
    项目管理的需求变更问题
    敏捷管理有一个原则就是:拥抱变化
    推荐5款体验最好的项目管理工具
  • 原文地址:https://www.cnblogs.com/LuDuo/p/10870404.html
Copyright © 2011-2022 走看看