计算几何-多边形重心公式 下载本文

内容发布更新时间 : 2024/5/21 12:10:51星期一 下面是文章的全部内容请认真阅读。

计算几何-多边形的重心

1. 1 累加和求重心

设平面上有N 个离散数据点( xi , yi ) ( i = 1, 2, ., n) , 其 多边形重心G( . x1, . y1) 为:

这是求多边形最简单直观的方法。可以直接利用离散数据点的x, y坐标就能求图形重心。但是缺陷在于没有对离散数据点所围图形做任何处理和分析,精度不够。 1. 2 算法一:在讲该算法时,先要明白下面几个定理。

定理1 已知三角形△A1A2A3的顶点坐标Ai ( xi , yi ) ( i =1, 2, 3) 。它的重心坐标为:

xg = (x1+x2+x3) / 3 ; yg = (y1+y2+y3) / 3 ;

定理2 已知三角形△A1A2A3的顶点坐标Ai ( xi , yi ) ( i =1, 2, 3) 。该三角形的面积为: S = ( (x2 - x1) * (y3 - y1) - (x3 - x1) * (y2 - y1) ) / 2 ; △A1A2A3 边界构成逆时针回路时取+ , 顺时针时取 -。

另外在求解的过程中,不需要考虑点的输入顺序是顺时针还是逆时针,相除后就抵消了。 原理:将多边形划分成n个小区域, 每个小区域面积为σi ,重心为Gi ( xi , 平面薄板重心公式把积分变成累加和:

yi ) ,利用求

由前面所提出的原理和数学定理可以得出求离散数据点所围多边形的一般重心公式:以Ai ( xi , yi ) ( i = 1, 2, ., n) 为顶点的任意N边形A1A2 .An ,将它划分成N - 2个三角形(如图1) 。每个三角形的重心为Gi (xi , . yi ) ,面积为σi。那么多边形的重心坐标G( x2, .y2) 为:

图1 多边形分解

例题:HDU 1115 Lifting the Stone 代码:如下。

1 #include 2 #include 3 #include 4structcentre 5 {

6double x , y ; 7 };

8intcas , n ;

9double Area( centre p0 , centre p1 , centre p2 )

10 {

11double area = 0 ;

12 area = p0.x * p1.y + p1.x * p2.y + p2.x * p0.y - p1.x * p0.y - p2.x * p1.y - p0.x * p2.y;

13return area / 2 ; // 另外在求解的过程中,不需要考虑点的输入顺序是顺时针还是逆时针,相除后就抵消了。 14 }

15int main () 16 {

17centre p0 , p1 , p2 ;

18doublesum_x , sum_y , sum_area , area; 19scanf ( \ , &cas ) ; 20while ( cas -- ) 21 {

22sum_x = sum_y = sum_area = 0 ; 23scanf ( \ , &n ) ;

24scanf ( \ , &p0.x , &p0.y ) ; 25scanf ( \ , &p1.x , &p1.y ) ; 26for ( int i = 2 ; i < n ; ++ i ) 27 {

28scanf ( \ , &p2.x , &p2.y ) ; 29 area = Area(p0,p1,p2) ; 30sum_area += area ;

31sum_x += (p0.x + p1.x + p2.x) * area ; 32sum_y += (p0.y + p1.y + p2.y) * area ; 33 p1 = p2 ; 34 }

35printf ( \ , sum_x / sum_area / 3 , sum_y / sum_area / 3 ) ; 36 } 37return0 ; 38 }