首页 > 代码库 > BZOJ 3505 CQOI2014 数三角形 组合数学
BZOJ 3505 CQOI2014 数三角形 组合数学
题目大意:
给定一个m*n的方格,求上面有多少个格点三角形
m,n<=1000
枚举O(m^3*n^3),铁定超时
我们选择补集法
首先我们任意选择三个不重复的点构成三角形 用组合数算出这一值 然后刨除三点一线的点即可
枚举三点之中在两边的点的横纵坐标之差,中间点的位置数为GCD(x,y)-1,统计答案即可
注意初始计算组合数时可能会爆int
#include<cstdio> #include<cstring> #include<iostream> #include<algorithm> using namespace std; typedef long long ll; int m,n; ll ans; int GCD(int x,int y) { if(!y)return x; return GCD(y,x%y); } int main() { int i,j; cin>>m>>n; ++m;++n; ans=m*n; ans=ans*(ans-1)*(ans-2)/6; for(i=0;i<=m;i++) for(j=0;j<=n;j++) if(i||j) { int gcd=GCD(i,j); ans-=(long long)(gcd-1)*(m-i)*(n-j)*(i&&j?2:1); } cout<<ans<<endl; }
BZOJ 3505 CQOI2014 数三角形 组合数学
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。