中国大学 MOOC 课程 《Python 语言程序设计》第七周课上练习

本程序通过Python模拟铅球投掷的运动轨迹,用户输入发射角度、初始速度等参数后,程序将计算并输出铅球飞行的距离。代码使用了数学公式来更新铅球的位置和速度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

中国大学 MOOC 课程 《Python 语言程序设计》第七周课上练习

1、铅球运行轨迹

from math import pi,sin,cos,radians
def main():
    angle,vel,h0,time = getInputs()
    xpos,ypos=0,h0
    xvel,yvel=getXYComponents(vel,angle)
    while ypos>= 0:
        xpos,ypos,yvel=updatePosition(time,xpos,ypos,xvel,yvel)
    print("\nDistance traveled:{0:0.1f}meters".format(xpos))

def getInputs():
    angle = eval(input("Enter the launch angle (in degrees):"))
    vel = eval(input("Enter the initial velocity (in meters/sec):"))
    h0 = eval(input("Enter the initial height (in meters):"))
    time = eval(input("Enter the time interval: "))
    return angle,vel,h0,time

def getXYComponents(vel,angle):
    thera=radians(angle)
    xvel=vel*cos(thera)
    yvel=vel*sin(thera)
    return xvel,yvel

def updatePosition(time,xpos,ypos,xvel,yvel):
    xpos=xpos+time*xvel
    yvell=yvel-9.8*time
    ypos=ypos+(yvel+yvell)/2.0
    yvel=yvell
    return xpos,ypos,yvel
main()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值