夹角有多大II
2014-12-06 16:31
190 查看
夹角有多大II
TimeLimit:1000/1000MS(Java/Others)MemoryLimit:32768/32768K(Java/Others)TotalSubmission(s):7426AcceptedSubmission(s):3734
[align=left]ProblemDescription[/align]
这次xhd面临的问题是这样的:在一个平面内有两个点,求两个点分别和原点的连线的夹角的大小。
注:夹角的范围[0,180],两个点不会在圆心出现。
[align=left]Input[/align]
输入数据的第一行是一个数据T,表示有T组数据。
每组数据有四个实数x1,y1,x2,y2分别表示两个点的坐标,这些实数的范围是[-10000,10000]。
[align=left]Output[/align]
对于每组输入数据,输出夹角的大小精确到小数点后两位。
[align=left]SampleInput[/align]
2 1122 1110
[align=left]SampleOutput[/align]
0.00 45.00
解题思路:考察acosx的用法
余弦定理。 cosC=(a^2+b^2-c^2)/(2·a·b) cosB=(a^2+c^2-b^2)/(2·a·c) cosA=(c^2+b^2-a^2)/(2·b·c) a,b,c为三角形三边长度,A,B,C分别为边a,b,c相对的角。
源代码:
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#definePI3.1415926
intmain()
{
intt;
doublex1,y1,x2,y2,answer;
doublea,b,c,up,down;
scanf("%d",&t);
while(t--)
{
scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);
a=x1*x1+y1*y1;
b=x2*x2+y2*y2;
c=(x2-x1)*(x2-x1)+(y2-y1)*(y2-y1);
up=a+b-c;
down=2*sqrt(a)*sqrt(b);
answer=acos(up/down);
printf("%.2lf\n",answer/PI*180);
}
system("pause");
return0;
}
相关文章推荐
- HDU 2080 夹角有多大II
- hdu2080夹角有多大II
- hdu 2080 夹角有多大II
- hdu2080 夹角有多大II(C语言)
- HDOJ2080 夹角有多大II
- HDOJ HDU 2080 夹角有多大II ACM 2080 IN HDU
- HDU 2080 夹角有多大II
- hoj2080夹角有多大II
- HDU 2080 夹角有多大II
- HDOJ 2080 夹角有多大II
- 水题堆2.U - 夹角有多大II
- HDU ACM 11 2080 夹角有多大II
- hdu-2080 夹角有多大II
- HDU2080 夹角有多大II
- hdu 2080 夹角有多大II
- HDU2080夹角有多大II
- HDU 2080 夹角有多大II
- *寒假水54——夹角有多大II【反三角函数】
- HDU 2080 夹角有多大II
- HDOJ 2080 夹角有多大II