P3166 [CQOI2014]数三角形

题目描述

给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个。下图为4x4的网格上的一个三角形。注意三角形的三点不能共线。

输入格式

输入一行,包含两个空格分隔的正整数m和n。

输出格式

输出一个正整数,为所求三角形数量。

输入输出样例

输入 #1

2 2

输出 #1

76

说明/提示

数据范围

bzoj上是1<=m,n<=1000

思路

  • 每个顶点都在格点上的三角形,有且只有一个可以被它完全覆盖的网格。所以只要求出原矩形当中所有子矩形的完全覆盖三角形的数量,就可以不重不漏地找出顶点都在格点上的三角形。

    ——但是子矩形好多啊,枚举左上角和右下角,至少是n^2m^2的数量级哇qwq

    ——注意到我们并不关心每个子矩形的位置,而只关心它们的长宽,以及长宽均相同的矩形的数目,所以枚举子矩形的长 i 和宽 j,则i∗j的矩形数量为(n−i+1)∗(m−j+1),子矩阵数量级降为nm。

    至此,原问题转化为

    给定网格的长宽,迅速求解完全覆盖网格的三角形的数目

  • 显然对于一个i∗j的网格(这里i,j指的是空格的数量而非格点,上图i=6,j=10),固定顶点的位置有四种,每种对应的另外两个顶点的位置有(i−1)∗(j−1)种(B C不能与N P Q重合),共4∗(i−1)∗(j−1)种。

    分析两个顶点在MNPQ角上的情况。不妨设A与M重合。此时另外一个角上的点(不妨设为点B)有三种情况:

    1、B与N重合。此时C一定在QP上。共(i−1)种情况。

    2、B与Q重合。此时C一定在NP上。共(j−1)种情况。

    3、B与P重合。

    这是比较麻烦的一种状态,因为此时C点可以在网格中能构成三角形的任意一处。但是我们注意到,如果线段AB除了经过M P之外,还经过了一些其他格点,C是不能与它们重合的。

    那么有多少个格点被AB穿过呢qwq?

    显然,不包括A本身,有gcd(i,j)−1个(至于为什么,请读者自己思考)

    所以第三种情况的方案数是(i+1)∗(j+1)−4−gcd(i,j)+1(这里−4是因为C点不能放在网格的四个角上)。

    注意到以上三种情况都可以反转,从而得到另一组与其一一对应的方案。

    分析三个顶点在MNPQ角上的情况。显然只有四种。

    综上,对于一个长宽为i,j的网格,可以把它完全覆盖的三角形的个数

    S=4∗(i−1)∗(j−1)+2∗[(i−1)+(j−1)+(i+1)∗(j+1)−4−gcd(i,j)+1]+4

    =6∗i∗j−2∗gcd(i,j)

    枚举子矩阵的复杂度为mn,单次求解gcd的复杂度为log(m+n),总复杂度O(mnlog(m+n)),实际运行跑的飞起。

    转自洛谷大佬https://www.luogu.org/blog/suwakow/solution-p3166

代码:

#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;

long long n,m,ans=0;

long long gcd(long long a,long long b) {
	if(a<b)
		swap(a,b);
	if(a%b==0)
		return b;
	else
		return gcd(b,a%b);
}

int main () {
	scanf("%lld%lld",&n,&m);
	for(long long i=1; i<=n; i++)
		for(long long j=1; j<=m; j++)
			ans+=(n-i+1)*(m-j+1)*(6*i*j-2*gcd(i,j));
	printf("%lld\n",ans);
	return 0;
}

原文地址:https://www.cnblogs.com/mysh/p/11296778.html

时间: 2024-10-07 15:09:40

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

bzoj3505 / P3166 [CQOI2014]数三角形

P3166 [CQOI2014]数三角形 前置知识:某两个点$(x_{1},,y_{1}),(x_{2},y_{2})\quad (x_{1}<x_{2},y_{1}<y_{2})$所连成的线段穿过整点的个数为$gcd(x_{2}-x_{1},y_{2}-y_{1})-1$ “注意三角形的三点不能共线.” 暗示你可以处理出总方案再减去三点共线的方案. 显然,总方案就是在$(n+1)*(m+1)$个点中任选$3$个.于是$tot=C((n+1)*(m+1),3)$ 现在我们要算出三点共线的方案

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

题目 给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个.下图为4x4的网格上的一个三角形. 注意三角形的三点不能共线. 输入格式 输入一行,包含两个空格分隔的正整数m和n. 输出格式 输出一个正整数,为所求三角形数量. 输入样例 2 2 输出样例 76 数据范围 1<=m,n<=1000 题解 比较容易想到的是用所有方案\(C_{n*m}^{3}\)减去共线的方案 水平和竖直共线很容易算,为\(n * C_{m}^{3}\)和\(m * C_{n}^{3}\) 主要是倾斜的线 我们

洛谷P3166 [CQOI2014]数三角形

题目描述 给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个.下图为4x4的网格上的一个三角形.注意三角形的三点不能共线. 输入输出格式 输入格式: 输入一行,包含两个空格分隔的正整数m和n. 输出格式: 输出一个正整数,为所求三角形数量. 输入输出样例 输入样例#1: 2 2 输出样例#1: 76 数据范围 1 ---------------------------------------------------------------------------------- 这道题呢

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

好题鸭.. 不好直接求三角形个数,那就用全集-补集,转化为求三点共线的数量. 具体求法是求出水平共线数量与竖直共线数量和斜线共线数量. 用排列组合的知识可知为水平和竖直的为$C_n^3$?与$C_m^3?$. 求斜线三点共线:显然,对于点$(a,b) (x,y)$连成的线段$(其中a>x,b>y)$,在它们中间有$gcd(a-x,b-y)-1$个整点,因此基本的思路就是枚举两个点,然后第3个点就是$gcd(a-x,b-y)-1$种可能了.我们又发现,这些线段是可以平移和对称(/和\)的,于是并

BZOJ 3505: [Cqoi2014]数三角形( 组合数 )

先n++, m++ 显然答案就是C(3, n*m) - m*C(3, n) - n*C(3, m) - cnt. 表示在全部点中选出3个的方案减去不合法的, 同一行/列的不合法方案很好求, 对角线的不合法方案cnt比较麻烦. 枚举对角线(左下-右上), 即(0, 0)-(x, y), 我们发现这种情况有(n-y)*(m-x)*2(算上左上-右下的)种, 然后中间有gcd(x, y)-1个点(不合法), 乘起来就好了. ---------------------------------------

【BZOJ3505】[Cqoi2014]数三角形 组合数

[BZOJ3505][Cqoi2014]数三角形 Description 给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个.下图为4x4的网格上的一个三角形. 注意三角形的三点不能共线. Input 输入一行,包含两个空格分隔的正整数m和n. Output 输出一个正整数,为所求三角形数量. Sample Input 2 2 Sample Output 76 数据范围 1<=m,n<=1000 题解:显然要用补集法,我们只需要求出三点共线的方案数即可.方法是先枚举两端的点所形成的向

3505: [Cqoi2014]数三角形

3505: [Cqoi2014]数三角形 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1324  Solved: 807[Submit][Status][Discuss] Description 给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个.下图为4x4的网格上的一个三角形. 注意三角形的三点不能共线. Input 输入一行,包含两个空格分隔的正整数m和n. Output 输出一个正整数,为所求三角形数量. Sample Inp

【BZOJ 3505】 [Cqoi2014]数三角形

3505: [Cqoi2014]数三角形 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 664 Solved: 403 [Submit][Status][Discuss] Description 给定一个nxm的网格,请计算三点都在格点上的三角形共有多少个.下图为4x4的网格上的一个三角形. 注意三角形的三点不能共线. Input 输入一行,包含两个空格分隔的正整数m和n. Output 输出一个正整数,为所求三角形数量. Sample Inpu

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

3505: [Cqoi2014]数三角形 Time Limits: 1000 ms  Memory Limits: 524288 KB  Detailed Limits Description Input 输入一行,包含两个空格分隔的正整数m和n. Output 输出一个正整数,为所求三角形数量. Sample Input 输入1: 1 1 输入2: 2 2 Sample Output 输出1: 4 输出2: 76 Data Constraint 对于30%的数据 1<=m,n<=10 对于1