传送门

直接求还要考虑各种不合法情况,不好计数

很容易想到容斥

把所有可能减去不合法的情况剩下的就是合法情况

那么我们只要任取不同的三点就是所有可能,不合法情况就是三点共线

对于两点 $(x_1,y_1)\ ,\ (x_2,y_2)$ ,它们之间有 $gcd(\left | x_1-x_2 \right |,\left | y_1-y_2 \right |)-1$ 个交点

证明?因为第三点C如果在两点A,B间的线上

那么$\frac{\left | x_A-x_C \right |}{ \left | y_A-y_C \right |}=\frac{\left | x_A-x_B \right |}{ \left | y_A-y_B \right |}$

因为 $x_C,y_C$ 为整数且在A,B之间,所以只有 $gcd(\left | x_A-x_B \right |,\left | y_A-y_B \right |)-1$ 个位置可取

自己画个图感性理解一下就好了

所以一个直接的思路就是枚举所有两个点A,B,算出C的数量

但是可以发现有很多线段AB其实本质是一样的,只是位置不同,我们可以通过平移来得到

把点A固定在原点上,然后枚举B,这样可以得到所有本质不同的线段

然后考虑有多少种平移方案

设 B 坐标为 (X,Y),那么线段可以向上平移最多 N-Y 个单位,向右平移最多 M-X 个单位

因为可以平移 0 个单位,所以共有 (N-Y+1)(M-X+1) 种方案

因为AB斜率可以为负,所以要把之前求出来的方案数再乘 2

在坐标系中任选3点的方案数为 $C_{(N+1)(M+1)}^{3}$

别忘了减去三点横坐标相同或纵坐标相同的情况:

对于每条横线,都有 $C_{M+1}^{3}$种方案,共 N 条横线

对于每条纵线,也是一样,为 $M*C_{N+1}^{3}$

别忘了开 long long

代码:

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cmath>
#include<cstring>
using namespace std;
typedef long long ll;
inline int read()
{
int x=,f=; char ch=getchar();
while(ch<''||ch>'') { if(ch=='-') f=-; ch=getchar(); }
while(ch>=''&&ch<='') { x=(x<<)+(x<<)+(ch^); ch=getchar(); }
return x*f;
}
int n,m,t;
ll ans;
int gcd(int a,int b) { return b ? gcd(b,a%b) : a; }
int main()
{
n=read()+; m=read()+;
t=n*m;
ans=1ll*t*(t-)*(t-)/(**) - 1ll* m* n*(n-)*(n-)/(**) - 1ll* n* m*(m-)*(m-)/(**);
//总方案数 - 纵线不合法方案 - 横线不合法方案
for(int i=;i<n;i++)//枚举点B纵坐标
for(int j=;j<m;j++)//横坐标
ans-=1ll*(n-i)*(m-j)*(gcd(i,j)-)*;//减去斜线不合法方案数
printf("%lld",ans);
return ;
}

P3166 [CQOI2014]数三角形的更多相关文章

  1. bzoj3505 / P3166 [CQOI2014]数三角形

    P3166 [CQOI2014]数三角形 前置知识:某两个点$(x_{1},,y_{1}),(x_{2},y_{2})\quad (x_{1}<x_{2},y_{1}<y_{2})$所连成 ...

  2. BZOJ3505 & 洛谷P3166 [Cqoi2014]数三角形 【数学、数论】

    题目 给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个.下图为4x4的网格上的一个三角形. 注意三角形的三点不能共线. 输入格式 输入一行,包含两个空格分隔的正整数m和n. 输出格式 输出 ...

  3. 【题解】洛谷P3166 [CQOI2014] 数三角形(组合+枚举)

    洛谷P3166:https://www.luogu.org/problemnew/show/P3166 思路 用组合数求出所有的3个点组合(包含不合法的) 把横竖的3个点共线的去掉 把斜的3个点共线的 ...

  4. 洛谷P3166 [CQOI2014]数三角形

    题目描述 给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个.下图为4x4的网格上的一个三角形.注意三角形的三点不能共线. 输入输出格式 输入格式: 输入一行,包含两个空格分隔的正整数m和n ...

  5. Luogu P3166 [CQOI2014]数三角形 组合数学

    好题鸭.. 不好直接求三角形个数,那就用全集-补集,转化为求三点共线的数量. 具体求法是求出水平共线数量与竖直共线数量和斜线共线数量. 用排列组合的知识可知为水平和竖直的为$C_n^3$​与$C_m^ ...

  6. [CQOI2014]数三角形 题解(组合数学+容斥)

    [CQOI2014]数三角形 题解(数论+容斥) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1328780 链接题目地址:洛谷P3166 BZOJ 350 ...

  7. BZOJ 3505: [Cqoi2014]数三角形 数学

    3505: [Cqoi2014]数三角形 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...

  8. Bzoj 3505: [Cqoi2014]数三角形 数论

    3505: [Cqoi2014]数三角形 Time Limits: 1000 ms  Memory Limits: 524288 KB  Detailed Limits   Description

  9. bzoj 3505: [Cqoi2014]数三角形 组合数学

    3505: [Cqoi2014]数三角形 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 478  Solved: 293[Submit][Status ...

随机推荐

  1. DAY8-python之网络编程

    一.客户端/服务器架构 1.硬件C/S架构(打印机) 2.软件C/S架构 互联网中处处是C/S架构 如黄色网站是服务端,你的浏览器是客户端(B/S架构也是C/S架构的一种) 腾讯作为服务端为你提供视频 ...

  2. js调试的一点小知识

    1.如果想要js代码被XHTML和HTML解析,就可以使用如下方式 <script type="text/javascript"> //<![CDATA[ fun ...

  3. css的relative与absolute(一)

    relative与absolute是position的两个值,本文对这两个值得关系进行了一个小实验 实验一: 首先定义了两个div元素,代码如下所示: <!doctype html> &l ...

  4. day17-jdbc 5.url介绍

    url用于标识数据库的位置,用于标识找哪个数据库. 总结:url是路径,其实就是确定是哪个数据库.用来确定我用的是哪一个数据库,并且通知我这个Connection或者是这个DriverManager获 ...

  5. Gstreamer编程

    一.简介 GStreamer是一个开源的多媒体框架库.利用它,可以构建一系列的媒体处理模块,包括从简单的ogg播放功能到复杂的音频(混音)和视频(非线性编辑)的处理.应用程序可以透明的利用解码和过滤技 ...

  6. 1、awk打开多个文件的方法

    转载:http://www.cnblogs.com/Berryxiong/p/6209324.html 1.当awk读取的文件只有两个的时候,比较常用的有三种方法(1)awk 'NR==FNR{... ...

  7. ZROI2018普转提day6t3

    传送门 分析 居然卡哈希数,万恶的出题人...... 感觉我这个方法似乎比较呆,我的代码成功成为了全网最慢的代码qwq 应该是可以直接哈希的 但由于我哈希学的不好又想练练线段树维护哈希,于是就写了个线 ...

  8. Entity Framework Code-First(23):Entity Framework Power Tools

    Entity Framework Power Tools: Entity Framework Power Tools (currently in beta 3) has been released. ...

  9. 数据结构 station

    问题描述 一天,小 L 突然对列车的进出站问题产生了兴趣,如下图所示:列车只能从 A 进站,或从 B 出站.列车从 A 进站,进站顺序为 1, 2, 3, 4, 5列车从 B 出站,出站顺序为 5, ...

  10. C#获取WINDOWS系统信息

    需引用System.Management命名空间, 具体代码如下: public class SysProp { public SysProp() { ManagementObjectSearcher ...