一道数学题,用皮克定理。
给定顶点坐标均是整点(或正方形格点)的简单多边形,皮克定理说明了其面积A和内部格点数目i、边上格点数目b的关系:
S = a + b/2 - 1。
#include<cstdio>
#include<iostream>#include <cmath>
#include <algorithm>
using namespace std;
int gb(int a,int b);
int main()
{
int a,b,c,k=0;
cin>>a>>b>>c;
k=c;
k+=gb(max(a,b),min(a,b));
int d=abs(c-a);
k+=gb(max(b,d),min(b,d));
int ans=c*b/2.0+1-k/2.0;
cout<<ans<<endl;
return 0;
}
int gb(int a,int b)
{
if(b==0)return a;
else return gb(b,a%b);
}
本文介绍了一道利用皮克定理解决的数学题目。皮克定理是一种用于计算平面中由整点构成的简单多边形面积的方法,公式为S=a+b/2-1,其中a为多边形内部的整点数,b为边界上的整点数。文章通过具体的编程实现展示了如何运用这一定理。


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



