逆时针给你等边三角形的两个顶点啊A,B,求第三个顶点的坐标。
思路:
将B点绕A点逆时针旋转60°就OK了~就是我们要找的C点的坐标。
这里注意要将60°转为为弧度,为 P1/3 弧度。
大水题呵呵~希望我比赛的时候也能一A就过过过~
0MS AC :
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
const double PI = acos(-1.0);
struct pnode
{
double x,y;
pnode(double a=0,double b=0):x(a),y(b){}
pnode operator + (const pnode&b)const
{
return pnode(x+b.x,y+b.y);
}
pnode operator - (const pnode&b)const
{
return pnode(x-b.x,y-b.y);
}
void pread()
{
scanf("%lf %lf",&x,&y);
}
};
typedef pnode myvec;
pnode a,b;
myvec rotat(myvec a,double rad)
{
return myvec(a.x*cos(rad)-a.y*sin(rad),a.x*sin(rad)+a.y*cos(rad));
}
int main()
{
int cas;
scanf("%d",&cas);
while(cas--)
{
a.pread();
b.pread();
myvec cha = rotat(b-a,PI/3.0);
cha = cha + a;
printf("(%0.2lf,%.2lf)\n",cha.x,cha.y);
}
return 0;
}