题意:为有一个等边三角形给出了两个点的坐标A(x1,y1),B(x2,y2),让你求C(x3,y3)的坐标,且A,B,C按逆时针排列;
开始想运用等边三角形的特有性质列两个方程解出C的坐标,emmm发现并不能行
然后真正的解题思路为按角来求
先求出AB这条边与x轴所成的夹角的sin(a),cos(a);
然后在求AC这条边与x所成夹角的值极为sin(a+60度),cos(a+60度)
解出这两个之后 sin(a+60度)=对边/斜边(斜边可以求出来)(因为是等边三角形)对边则用y3-y1;可以求出 y3;
同理 利用cos(a+60度)求出x3;
那么为什么这就是解呢,怎么判断是逆时针呢
因为你这么求就是按照ABC是顺时针排列的时候求出来的各种值,当顺时针时就会改变了
所以代码如下
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
int main()
{
int t;
scanf("%d",&t);
double x1,y1,x2,y2,x3,y3;
while(t--)
{
scanf("%lf %lf %lf %lf",&x1,&y1,&x2,&y2);
double d = sqrt((x1 - x2)*(x1 - x2) + (y1 - y2)*(y1 - y2));
double si = ((y2 - y1))/(d);
double co = ((x2 - x1))/(d);
y3 = (si*d/2.0) + ((sqrt(3.0)/2.0)*co*d) + y1;
x3 = (co*d/2.0) - ((sqrt(3.0)/2.0)*si*d) + x1;
printf("(%.2f,%.2f)\n",x3,y3);
}
return 0;
}