【USACO3.4.3】电网

51 篇文章 0 订阅
2 篇文章 0 订阅

皮克定理!!!

程序最后有讲解

/*
TASK:fence9
LANG:C++
*/
#include <iostream>
inline int abs(int k){if (k < 0)return -k;return k;}
int n, m, p;
 
int gcd(int a, int b){return !a ? b : gcd(b % a, a);}
 
inline int cal2(int x, int y)
{
	if (!x)	return y + 1;
	return gcd(x, y) +1;
}
 
int main()
{
	//freopen("fence9.in", "r", stdin);
	//freopen("fence9.out", "w", stdout);
	std::cin >> n >> m >> p;
	int S = p * m / 2;
	int t = cal2(n, m) + cal2(abs(n - p), m) + p - 2;
	std::cout << S + 1 - t / 2 << std::endl;
	return 0;
}
//皮克定理说明了其面积A和内部格点数目i、边上格点数目b的关系:A = i + b/2 - 1
//可以证明,一条直线((0,0),(n,m))上的格点数等于n与m的最大公约数+1。
//即b=gcd(n,m)+1. gcd(n,m)为n与m的最大公约数。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值