首页 > 其他分享 >模拟体育竞技

模拟体育竞技

时间:2023-12-20 10:46:06浏览次数:30  
标签:scoreA scoreB random probB probA 模拟 体育竞技 def

from random import random

def printIntro(): # 打印程序介绍信息
print('这个程序模拟两个队伍A和B的排球竞技比赛')
print('程序运行需要A和B的能力值(以0到1之间的小数表示)')
print('35毛润松')

def getInputs(): # 获得程序运行参数
a = eval(input('请输入队伍A的能力值(0-1):'))
b = eval(input('请输入队伍B的能力值(0-1):'))
n = eval(input('模拟比赛场次:'))
return a, b, n

def simOneGame(probA, probB): # 进行决赛
scoreA, scoreB =0, 0
serving = 'A'
while not gameOver(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 simfirstgame(probA, probB):
scoreA, scoreB = 0, 0
for i in range(4):
s1, s2=0, 0
while not gameover(s1, s2):
if random()<probA:
s1+=1
elif random()<probB:
s2+=1
if s1>s2:
scoreA+=1
else:
scoreB+=1
return scoreA, scoreB

def simNGames(n, probA, probB): #进行N场比赛
winsA, winsB = 0, 0 # 初始化AB的胜场数
for i in range(n):
k, l=simfirstgame(probA, probB)
if k==1:
winsB+=1
continue
elif k==3:
winsA+=1
continue
scoreA, scoreB = simOneGame(probA, probB)
if scoreA > scoreB:
winsA += 1
else:
winsB += 1
return winsA, winsB

def gameOver(c, d): #比赛结束
return (c>=15 and c-d>=2) or (d>=15 and d-c>=2)
def gameover(scoreA, scoreB):
return (scoreA>=25 and scoreA-scoreB>=2) or (scoreB>=25 and scoreB-scoreA>=2)


def printSummary(n ,winA, winB): #打印比赛结果
print('竞技分析开始,共模拟{}场比赛'.format(n))
print('队伍A获胜{}场比赛,占比{:.2f}%'.format(winA, winA/n*100))
print('队伍B获胜{}场比赛,占比{:.2f}%'.format(winB, winB / n * 100))
def main():
printIntro()
probA, probB, n =getInputs()
winsA, winsB = simNGames(n, probA, probB)
printSummary(n, winsA, winsB)

main()

 

标签:scoreA,scoreB,random,probB,probA,模拟,体育竞技,def
From: https://www.cnblogs.com/xx0228/p/17915958.html

相关文章

  • Midjourney模拟API生图调用
    目前Midjourney没有对外开放API接口,所以通过MJ自动化生图的主要方式是,集成Discord应用机器人,通过机器人与MJ机器人进行交互,并监听频道内的生图结果,最终拿到图片地址。简单介绍下步骤一、购买MJ账号二、获取账号Authorization在网页中向MidjourneyBot发送/imagine进行生图我......
  • 9-18-模拟赛-20
    title:9.18模拟赛#20date:2023-09-1815:11:52categories:-题解top:#114T1手玩后发现第一个人的最后个数最多,易证。然后考虑别人给了他多少贡献,应为\(\frac{m}{3}+\frac{\frac{m}{3}}{3}+\frac{a_n}{3}\)。其中\(a_n\)为\(n\)开始分前的数量。发现\(\foral......
  • 网页在线编辑Excel表格,调用本机Office,非模拟,插入图片,导出PDF全屏编辑
    Excel作为微软Office的重要组成部分,在各行业中应用非常广泛,随着互联网及云计算的普及,网页在线编辑Excel表格也越来越成文更多人的广泛需求,而在网页中却无法直接在线编辑微软Office,下面介绍一种Web网页在线编辑Excel表格方案,可以调用本机原生Offce软件,直接在网页上编辑Excel表格。......
  • 三道初三数学模拟几何综合题的解题思路解析
     ......
  • 比赛模拟程序设计
    模拟体育竞技分析:a.采用乒乓球比赛规则(学号尾号为0,1,2,3同学必做及格题)。‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬......
  • 模拟集成电路设计系列博客——4.3.1 有源RC滤波器
    4.3.1有源RC滤波器除了Gm-C滤波器外,另一种实现模拟集成滤波器的方案是有源RC滤波器或者MOSFET-C滤波器。在这两个技术中,电流的积分都是通过反馈连接在一个高增益放大器的电容上实现的,这与将电流积分电容连接到地的Gm-C滤波器方案不同。有时这种方案被叫做米勒积分,因为就像两级放......
  • C0328 【1005 C组】模拟测试 斜率 题解
    原题链接:斜率。题意在一个平面直角坐标系中,给定\(n\)个点的横纵坐标,求出哪两个点所构成的连线的斜率最接近\(\frac{P}{Q}\)。数据范围:\(n\le1000000\)。思路显然这是一道数学题,不能直接暴力去找答案。首先我们可以弱化一下题目,求出斜率最接近\(y=0\)即\(x\)轴的两......
  • 模拟体育竞技分析之采用排球比赛规则
    (1)模拟体育竞技分析:(不同学号选做不同题目,必做题)b.采用排球比赛规则(学号尾号为4,5,6同学必做及格题)。赛制规定:‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪......
  • VISSIM模拟上海松江新城小区道路开放及交通状况改善分析
    全文链接:https://tecdat.cn/?p=34593原文出处:拓端数据部落公众号分析师:MingmingZhao上海市近年来不断增长的高峰出行车辆数,带来了交通负荷严重等城市问题,本项目主要探究开放封闭式小区能否实现对道路交通状况的改善。对道路交通状况的综合分析基于对道路不同时间段、不同位置......
  • 模拟电路噪声计算
    运放电路噪声怎么计算?手把手计算指南,文末附自动计算工具!-知乎(zhihu.com) 噪声计算工具已经通过官网下载,下载地址为:http://e2e.ti.com/cfs-file.ashx/__key/communityserver-blogs-components-weblogfiles/00-00-00-08-64/4812.Flicker-Noise-v1.xlsx ......