题意简述
原点处有一盏灯,左、右各有一面镜子,分别位于 、。两镜对照产生无穷多个像。 次询问,每次求左侧或右侧第 个像的坐标。
解题思路
高达 ,必须直接算出第 个像的位置,不能逐次反射。
记左、右镜到原点的距离为 、。观察左侧前几个像到原点的距离:,每往后一个像交替增加 、。于是左侧第 个像到原点的距离为
坐标取其相反数。右侧完全对称,把 、 的系数互换即可。
整数实现中 为 , 为 。每次询问 作答,坐标可达 量级,用 位整数。
时间复杂度为 。
参考代码
#include <bits/stdc++.h>
using namespace std;
using ll=long long;
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr);
int t;
ll l,r;
cin>>t>>l>>r;
while(t--)
{
char c;
ll x;
cin>>c>>x;
ll a=(x+1)/2,b=x/2;
cout<<(c=='L'?-2*(a*l+b*r):2*(a*r+b*l))<<'\n';
}
return 0;
}