首页 > 其他 > 详细

bzoj3621我想那还真是令人高兴啊

时间:2016-08-16 23:44:06      阅读:297      评论:0      收藏:0      [点我收藏+]

bzoj3621我想那还真是令人高兴啊

题意:

T组数据,每组给出两个三角形各点坐标,要求求出一个点使第一个三角形可以绕这个点放缩和旋转得到另一个三角形。T≤10,坐标为≤10000的实数,数据保证三角形不用平移,答案保留三位小数。

题解:

复数既是一种数,又可以当做一种独特的二维向量,因为其数的特点可以用来解方程,又因为其向量的特点可以表示二维的点和变换。两个复数的积在几何上定义为把它转化为向量后极角相加,长度相乘,正可以用来表示放缩和旋转变换。因此设A,B,C为变换前三角形三个顶点(用复数表示),T为变换复数,P为绕的那个点,A‘,B‘,C‘表示变换后的点。于是可以列方程(A-P)*T=(A‘-P) (B-P)*T=(B‘-P) (C-P)*T=(C‘-P),我们可以枚举A,B,C分别是第一个三角形的哪个顶点,然后联立前两道解出T代入第三道验证。然而本傻逼忘记枚举了导致WA了好几发,顺便安利STL的complex类,已经包装好了复数的常用运算。

代码:

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <algorithm>
 4 #include <queue>
 5 #include <complex>
 6 #define inc(i,j,k) for(int i=j;i<=k;i++)
 7 using namespace std;
 8 
 9 complex <double> a,b,c,d,e,f,t,p,g;
10 int T;
11 int main(){
12     scanf("%d",&T); while(T--){
13         double x,y;
14         scanf("%lf%lf",&x,&y); a.real(x); a.imag(y);
15         scanf("%lf%lf",&x,&y); b.real(x); b.imag(y);
16         scanf("%lf%lf",&x,&y); c.real(x); c.imag(y);
17         scanf("%lf%lf",&x,&y); d.real(x); d.imag(y);
18         scanf("%lf%lf",&x,&y); e.real(x); e.imag(y);
19         scanf("%lf%lf",&x,&y); f.real(x); f.imag(y);
20         g.real(1.000000),g.imag(0.000000); t=(e-d)/(b-a); p=(a*t-d)/(t-g);
21         if(abs(((c-p)*t-(f-p)).real())<1e-4&&abs(((c-p)*t-(f-p)).imag())<1e-4){
22             printf("%.6lf %.6lf\n",p.real(),p.imag()); continue;
23         }
24         swap(b,c); t=(e-d)/(b-a); p=(a*t-d)/(t-g);
25         if(abs(((c-p)*t-(f-p)).real())<1e-4&&abs(((c-p)*t-(f-p)).imag())<1e-4){
26             printf("%.6lf %.6lf\n",p.real(),p.imag()); continue;
27         }
28         swap(a,b); t=(e-d)/(b-a); p=(a*t-d)/(t-g);
29         if(abs(((c-p)*t-(f-p)).real())<1e-4&&abs(((c-p)*t-(f-p)).imag())<1e-4){
30             printf("%.6lf %.6lf\n",p.real(),p.imag()); continue;
31         }
32         swap(b,c); t=(e-d)/(b-a); p=(a*t-d)/(t-g);
33         if(abs(((c-p)*t-(f-p)).real())<1e-4&&abs(((c-p)*t-(f-p)).imag())<1e-4){
34             printf("%.6lf %.6lf\n",p.real(),p.imag()); continue;
35         }
36         swap(a,b); t=(e-d)/(b-a); p=(a*t-d)/(t-g);
37         if(abs(((c-p)*t-(f-p)).real())<1e-4&&abs(((c-p)*t-(f-p)).imag())<1e-4){
38             printf("%.6lf %.6lf\n",p.real(),p.imag()); continue;
39         }
40         swap(b,c); t=(e-d)/(b-a); p=(a*t-d)/(t-g);
41         if(abs(((c-p)*t-(f-p)).real())<1e-4&&abs(((c-p)*t-(f-p)).imag())<1e-4){
42             printf("%.6lf %.6lf\n",p.real(),p.imag()); continue;
43         }
44     }
45     return 0;
46 }

 

20160609

bzoj3621我想那还真是令人高兴啊

原文:http://www.cnblogs.com/YuanZiming/p/5778201.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!