2020 Multi-University Training Contest 3---- HDU--6798、Triangle Collision(计算几何)

这是一篇关于2020年多校训练赛第3场中,HDU 6798题目——Triangle Collision的解析。题目涉及等边三角形内的一个点,根据给定的初始位置和速度,计算点与三角形边界发生k次完全弹性碰撞的时间。官方题解提出了将空间视为无限大平面,通过分解速度和距离来确定相交次数的方法,避免了与顶点的碰撞问题,并给出了上界估算的注意事项。文章可能包含相关代码实现。
摘要由CSDN通过智能技术生成

题目链接

题面:
在这里插入图片描述

题意:
给一个等边三角形,初始时刻有一个点在其中,位置和速度矢量已知,这个球和三角形的边界发生完全弹性碰撞,且不记摩擦,求第k次碰撞发生的时间。k≤106

官方题解:
在这里插入图片描述

在这里插入图片描述

我们把空间看为一张这样的无限大的平面。
问题就变成了求小球做直线匀速运动,且与途中的边第k次相交是什么时候。

我们发现图中的边可以分为三组平行线。
我们把小球的速度和初始距离沿垂直于三组平行线的方向分解,那么可以在已知时间的情况下O(1)计算出这段时间内,小球与多少条边相交(分别计算三个方向分别相交了几次相加即可)。由于题目保证前k次以内不会碰到顶点,所以不会有重,之后发生重合也不影响二分的正确性。

上界估算一下就可以啦。

注意:eps太小会TLE。

代码:

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<string>
#include<queue>
#include<bitset>
#include<map>
#include<unordered_map>
#include<set>
#include<list>
#define ui unsigned int
#define ll long long
#define llu unsigned ll
#define ld long double
#define pr make_pair
#define pb push_back
#define lc (cnt<<1)
#define rc (cnt<<1|1)
//#define len(x)  (t[(x)].r-t[(x)].l+1)
#define tmid ((l+r)>>1)
#define max(x,y) ((x)>(y)?(x):(y))
#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值