201803-2 python CCF 更简单的思路和代码 100分

本文介绍了一个使用Python实现的小球碰撞模拟算法。通过三个列表分别跟踪小球的位置、方向和数量,算法模拟了小球在固定长度空间内的运动,包括与边界和其它小球的碰撞。该算法适用于理解基本的物理碰撞原理和编程模拟。
n, L, t = map(int, input().split())
ball_positions = list(map(int, input().split()))
ball_directions = [1] * n
for i in range(t):
    ball_hits = list(map(ball_positions.count, ball_positions))#统计每个位置的球的数量
    for i in range(n):
        if ball_positions[i] == L or ball_positions[i] == 0:#检查端点
            ball_directions[i] = -ball_directions[i]
        if ball_hits[i] == 2:#检查相撞
            ball_directions[i] = -ball_directions[i]
        ball_positions[i] += ball_directions[i]#小球开始运动一秒
print(" ".join(map(str, ball_positions)))

思路:模拟小球真实运动就可以了,三个list分别存放小球的当前位置,小球的当前速度(矢量),当前位置的小球数量

注意:此解法未考虑初始时刻两个小球在端点位置的情况,如若考虑的话,先判断相撞,再判断端点,且修改下面代码

if ball_positions[i] == L or ball_positions[i] == 0:#检查端点
            ball_directions[i] = -ball_directions[i]

if ball_positions[i] == L:#检查端点
            ball_directions[i] = -1
if ball_positions[i] == 0:#检查端点
            ball_directions[i] = 1
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值