多边形重心问题acm我的怎么是wrong answer?
http://acm.nyist.net/JudgeOnline/problem.php?pid=3样例过了。。它的精确还要限制吗……谢谢了,哪个错了。。我用的是多边形面...
http://acm.nyist.net/JudgeOnline/problem.php?pid=3
样例过了。。它的精确还要限制吗……谢谢了,哪个错了。。我用的是多边形面积公式,重心坐标公式,感觉没错。
#include<iostream>
#include<cmath>
#include<stdio.h>
using namespace std;
struct point
{
double x;
double y;
};
int main()
{
int n,m,i;
point a[10000];
cin>>n;
while(n--)
{
double area=0;
double x1=0;
double y1=0;
cin>>m;
for(i=0;i<m;i++)
cin>>a[i].x>>a[i].y;
for(i=0;i<=m-2;i++)
area+=a[i].x*a[i+1].y;
for(i=1;i<=m-1;i++)
area-=a[i].x*a[i-1].y;
area=area+a[m-1].x*a[0].y-a[0].x*a[m-1].y;
area=fabs(area)/2;
for(i=1;i<=m-2;i++)
x1+=(a[0].x+a[i].x+a[i+1].x)/3*(fabs(a[0].x*a[i].y+a[i].x*a[i+1].y+a[i+1].x*a[0].y-a[i].x*a[0].y-a[i+1].x*a[i].y-a[0].x*a[i+1].y)/2);
for(i=1;i<=m-2;i++)
y1+=(a[0].y+a[i].y+a[i+1].y)/3*(fabs(a[0].x*a[i].y+a[i].x*a[i+1].y+a[i+1].x*a[0].y-a[i].x*a[0].y-a[i+1].x*a[i].y-a[0].x*a[i+1].y)/2);
x1=x1/area;
y1=y1/area;
if(area<0.00001)
printf("0.000 0.000\n");
else
{ printf("%.3lf ",area);
printf("%.3lf\n",x1+y1);}
}
return 0;
} 展开
样例过了。。它的精确还要限制吗……谢谢了,哪个错了。。我用的是多边形面积公式,重心坐标公式,感觉没错。
#include<iostream>
#include<cmath>
#include<stdio.h>
using namespace std;
struct point
{
double x;
double y;
};
int main()
{
int n,m,i;
point a[10000];
cin>>n;
while(n--)
{
double area=0;
double x1=0;
double y1=0;
cin>>m;
for(i=0;i<m;i++)
cin>>a[i].x>>a[i].y;
for(i=0;i<=m-2;i++)
area+=a[i].x*a[i+1].y;
for(i=1;i<=m-1;i++)
area-=a[i].x*a[i-1].y;
area=area+a[m-1].x*a[0].y-a[0].x*a[m-1].y;
area=fabs(area)/2;
for(i=1;i<=m-2;i++)
x1+=(a[0].x+a[i].x+a[i+1].x)/3*(fabs(a[0].x*a[i].y+a[i].x*a[i+1].y+a[i+1].x*a[0].y-a[i].x*a[0].y-a[i+1].x*a[i].y-a[0].x*a[i+1].y)/2);
for(i=1;i<=m-2;i++)
y1+=(a[0].y+a[i].y+a[i+1].y)/3*(fabs(a[0].x*a[i].y+a[i].x*a[i+1].y+a[i+1].x*a[0].y-a[i].x*a[0].y-a[i+1].x*a[i].y-a[0].x*a[i+1].y)/2);
x1=x1/area;
y1=y1/area;
if(area<0.00001)
printf("0.000 0.000\n");
else
{ printf("%.3lf ",area);
printf("%.3lf\n",x1+y1);}
}
return 0;
} 展开
1个回答
展开全部
#include<iostream>
#include<cmath>
#include<stdio.h>
using namespace std;
struct point {
double x;
double y;
};
int main() {
int n, m, i;
point a[10000];
cin >> n;
while (n--) {
double area = 0;
double x1 = 0;
double y1 = 0;
cin >> m;
for (i = 0; i < m; i++) {
cin >> a[i].x >> a[i].y;
}
for (i = 1; i <= m - 2; i++) {
double temp = ((a[i].x - a[0].x) * (a[i + 1].y - a[0].y)
- (a[i].y - a[0].y) * (a[i + 1].x - a[0].x)) / 2.0;
x1 += (a[0].x + a[i].x + a[i + 1].x) / 3.0 * temp;
y1 += (a[0].y + a[i].y + a[i + 1].y) / 3.0 * temp;
area += temp;
}
x1 = x1 / area;
y1 = y1 / area;
area = fabs(area);
if (area < 1e-6)
printf("0.000 0.000\n");
else {
printf("%.3f ", area);
printf("%.3f\n", x1 + y1);
}
}
return 0;
}
计算重心的时候,面积部分不应该带fabs
更多追问追答
追问
哦。。谢谢,还有那个精确度是怎么回事呢。。
追答
你只要x1和y1里面的两个fabs去掉,然后取反就可以了
Sievers分析仪
2024-12-30 广告
2024-12-30 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准...
点击进入详情页
本回答由Sievers分析仪提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询