多边形重心,面积

多边形面积

改革春风吹满地

#include<bits/stdc++.h>
using namespace std;
struct point
{
   double x,y;
}node[10001];
double cosr(point a,point b,point c)
{
   return (a.x-c.x)*(b.y-c.y)-(a.y-c.y)*(b.x-c.x);
}
int main( )
{
   int n;
   while(cin>>n&&n)
   {
       double sum=0;
       for(int i=0;i<n;i++)
       {
          cin>>node[i].x>>node[i].y;
       }
       for(int i=1;i<n-1;i++)
       {
          sum+=cosr(node[i],node[i+1],node[0]);
       }
       printf("%.1lf\n",sum/2.0);
   }
   return 0;
}

多边形重心

#include<bits/stdc++.h>
using namespace std;
struct tree
{
   double x,y;
} node[1000010];
double sum(tree a,tree b,tree c)
{
   return (a.x-c.x)*(b.y-c.y)-(b.x-c.x)*(a.y-c.y);
}
int main( )
{
   int t,n;
   cin>>t;
   while(t--)
   {
       cin>>n;
       double res=0;
       double ans=0;
       tree p;
       p.x=0;
       p.y=0;
       for(int i=0; i<n; i++)
       {
           cin>>node[i].x>>node[i].y;
       }
       for(int i=1; i<n-1; i++)
       {
           ans=sum(node[i],node[i+1],node[0]);
           res+=ans;
           p.x+=ans*(node[i].x+node[i+1].x+node[0].x)*1.0/3;
           p.y+=ans*(node[i].y+node[i+1].y+node[0].y)*1.0/3;
       }
       p.x/=res*1.0;
       p.y/=res*1.0;
       printf("%.2lf %.2lf\n",p.x,p.y);
   }

   return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,421评论 0 2
  • 第1章 第一个C程序第2章 C语言基础第3章 变量和数据类型第4章 顺序结构程序设计第5章 条件结构程序设计第6章...
    小狮子365阅读 10,735评论 3 71
  • 贪心算法 贪心算法总是作出在当前看来最好的选择。也就是说贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上...
    fredal阅读 9,289评论 3 52
  • 2019-06-10 各位领导老师,大家下午好,我是李家学校的王晓迟,非常感谢领导和老师能给我这样一个机会,在这里...
    龙潭李家王晓迟阅读 98评论 0 0
  • 今天是植树节,作为一个公民,今天应该尽一些义务。 看到微信朋友圈里,大家都参与挖坑栽树活动,立马心急。试想着和往年...
    李月芳阅读 747评论 3 32