Convex
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submission(s): 1497 Accepted Submission(s): 996
Problem Description
We have a special convex that all points have the same distance to origin point.
As you know we can get N segments after linking the origin point and the points on the convex. We can also get N angles between each pair of the neighbor segments.
Now give you the data about the angle, please calculate the area of the convex
As you know we can get N segments after linking the origin point and the points on the convex. We can also get N angles between each pair of the neighbor segments.
Now give you the data about the angle, please calculate the area of the convex
Input
There are multiple test cases.
The first line contains two integer N and D indicating the number of the points and their distance to origin. (3 <= N <= 10, 1 <= D <= 10)
The next lines contain N integers indicating the angles. The sum of the N numbers is always 360.
The first line contains two integer N and D indicating the number of the points and their distance to origin. (3 <= N <= 10, 1 <= D <= 10)
The next lines contain N integers indicating the angles. The sum of the N numbers is always 360.
Output
For each test case output one float numbers indicating the area of the convex. The printed values should have 3 digits after the decimal point.
Sample Input
4 190 90 90 906 160 60 60 60 60 60
Sample Output
2.0002.598
Source
Recommend
wange2014
题意:求一个凸边形的面积。 给了你n个相邻连线(
凸边形的各点与原点连线)的角度,和连线长度。
思路:用求三角形面积公式S=a*b*sin(c)/2;
代码:
#include<math.h>
#include<stdio.h>
#include<algorithm>
using namespace std;
#define PI 3.1415926
int main()
{
int n,k;
double ans=0,a;
while(~scanf("%d %d",&n,&k))
{
ans=0;
for(int i=1;i<=n;i++)
{
scanf("%lf",&a);
ans+=k*k*sin(a*PI/180)/2;
}
printf("%.3lf\n",ans);
}
return 0;
}
#include<stdio.h>
#include<algorithm>
using namespace std;
#define PI 3.1415926
int main()
{
int n,k;
double ans=0,a;
while(~scanf("%d %d",&n,&k))
{
ans=0;
for(int i=1;i<=n;i++)
{
scanf("%lf",&a);
ans+=k*k*sin(a*PI/180)/2;
}
printf("%.3lf\n",ans);
}
return 0;
}
395

被折叠的 条评论
为什么被折叠?



