热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

hdu2848VisibleTrees(容斥原理)

题意:给n*m个点(1≤m,n≤1e5),左下角的点为(1,1),右上角的点(n,m),一个人站在(0,0&#



题意:

给n*m个点(1 ≤ m, n ≤ 1e5),左下角的点为(1,1),右上角的点(n,m),一个人站在(0,0)看这些点。在一条直线上,只能看到最前面的一个点,后面的被档住看不到,求这个人能看到多少个点。

 

知识点:

容斥原理:(容许) 先不考虑重叠的情况,把包含于某条件中的所有对象的数目先计算出来,(排斥)然后再把计数时重复计算的数目排斥出去,使得计算的结果既无遗漏又无重复。

公式:          奇加偶减

一般求互质个数若用欧拉函数不好解决,则从反面考虑,用容斥。

 

模板:

void dfs(int c,int cur,int i,int j,LL ans1) //dfs(c,1,i,0,1);
{if(cur==c+1){if(c&1)ans-=ma/ans1;elseans+=ma/ans1;return;}for(;j}


 

题解:在同一条直线上的点的形式都是(ka,kb),这些点只能看到第一个。若gcd(a,b)==k’,(k’!=1),则其还能写成    (k’a’,k’b’)的形式。直到gcd(a,b)==1,(a,b)为第一个点。That is say,只要求出1~n与1~m中互质的数的个数,这题就OK了。一般求互质个数若用欧拉函数不好解决,则从反面考虑,用容斥。x为1~n中的一个数,x与1~m中互质的数的个数怎么求呢?用容斥,先找到有多少个数和x有1个公共的质因子,然后加上;再找到有多少个数与x有2个公共的质因子,然后减去;再找到有多少个数有多少个数与x有3个公共的质因子,然后加上……最后得到的个数,就是有多少个数与x不互质。

 

#include
#include
#include
using namespace std;
typedef long long LL;
const int N=1e5+10;
int ma,mi;
LL ans;int syz[N][7]; //素因子分解结果
int cnt[N];
void init() //筛选法求syz
{memset(cnt,0,sizeof(cnt));for(int i=2;i}void dfs(int c,int cur,int i,int j,LL ans1) //dfs(c,1,i,0,1);
{if(cur==c+1){if(c&1)ans-=ma/ans1;elseans+=ma/ans1;return;}for(;j}int main()
{int t;cin>>t;init();LL m,n;while(t--){scanf("%lld%lld",&m,&n);ans&#61;m*n;ma&#61;max(m,n),mi&#61;min(m,n);for(int i&#61;2;i<&#61;mi;i&#43;&#43;){for(int c&#61;1;c<&#61;cnt[i];c&#43;&#43;){dfs(c,1,i,0,1);}}printf("%I64d\n",ans);}return 0;
}


 

 

 

 

Visible Trees

Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u

Submit Status

Description

There are many trees forming a m * n grid, the grid starts from (1,1). Farmer Sherlock is standing at (0,0) point. He wonders how many trees he can see.
If two trees and Sherlock are in one line, Farmer Sherlock can only see the tree nearest to him.

Input

The first line contains one integer t, represents the number of test cases. Then there are multiple test cases. For each test case there is one line containing two integers m and n(1 ≤ m, n ≤ 100000)

Output

For each test case output one line represents the number of trees Farmer Sherlock can see.

Sample Input

2
1 1
2 3

Sample Output

1
5



推荐阅读
author-avatar
藏A组合别_577
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有