zoj3435(莫比乌斯反演)
题目链接: http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3435
题意: 给出一个三维坐标 (x, y, z), 问该点与 (1, 1, 1) 组成的长方体中有多少条经过点 (1, 1, 1) 的直线 .
思路: 显然本题的难点是线段不能重复计算, 比如 (1, 1, 1) 到 (2, 2, 2) 和 (1, 1, 1) 到 (4, 4, 4) 同一条直线 .
为了计算方便, 我们先将这个问题替换成它的等价问题: 求 (0, 0, 0), (x - 1, y - 1 , z - 1) 组成的长方体中有多少条经过 (0, 0, 0) 的直线 .
通过画图可以发现当且仅当点 (j, k, l) 满足 gcd(j, k, l) = 1 时累计直线 (0, 0, 0), (j, k, l) 刚好能累加到所有直线并且不会重复计算 .
然后我们将满足条件的直线分为 3 部分:
1. 从 (0, 0, 0) 出发的 3 条棱;
2. 从 (0, 0, 0) 出发的 3 个表面;
3. 从 (0, 0, 0) 出发到长方体内部的直线;
对于 1, 显然满足条件的直线为 3 条;
对于 2, 满足条件的直线数目为 gcd(j, k) = 1 的直线数目加 gcd(j, l) = 1 的直线数目加 gcd(k, l) = 1 的直线数目, 其中 1 <= j <= x -1, 1 <= k <= y - 1, 1 <= l <= z -1;
对于 3, 满足条件的直线数目为 gcd(j, k, l) = 1 的直线数目, 其中 1 <= j <= x -1, 1 <= k <= y - 1, 1 <= l <= z -1;
显然对于上面的计算部分都可以用莫比乌斯反演在线性时间内完成 .
代码:
#include <iostream>
#include <stdio.h>
#include <string.h>
#define ll long long
using namespace std; const int MAXN = 1e6 + ; bool check[MAXN];
int prime[MAXN], mu[MAXN], sum[MAXN]; void Moblus(void){
memset(check, false, sizeof(check));
int tot = ;
mu[] = ;
sum[] = ;
for(int i = ; i < MAXN; i++){
if(!check[i]){
prime[tot++] = i;
mu[i] = -;
}
for(int j = ; j < tot && prime[j] * i < MAXN; j++){
check[prime[j] * i] = true;
if(i % prime[j] == ){
mu[i * prime[j]] = ;
break;
}else mu[i * prime[j]] = -mu[i];
}
sum[i] = sum[i - ] + mu[i];
}
} ll solve(int x, int y){
ll ans = ;
if(x > y) swap(x, y);
for(int i = , la = ; i <= x; i = la + ){
la = min(x / (x / i), y / (y / i));
ans += (ll)(sum[la] - sum[i - ]) * (x / i) * (y / i);
}
return ans;
} ll solve(int x, int y, int z){
ll ans = ;
if(x > y) swap(x, y);
if(x > z) swap(x, z);
for(int i = , la = ; i <= x; i = la + ){
la = min(min(x / (x / i), y / (y / i)), z / (z / i));
ans += (ll)(sum[la] - sum[i - ]) * (x / i) * (y / i) * (z / i);
}
return ans;
} int main(void){
Moblus();
int x, y, z;
while(~scanf("%d%d%d", &x, &y, &z)){
x--;
y--;
z--;
ll ans = ;
ans += solve(x, y);
ans += solve(x, z);
ans += solve(y, z);
ans += solve(x, y, z);
printf("%lld\n", ans);
}
return ;
}
zoj3435(莫比乌斯反演)的更多相关文章
- hdu1695 GCD(莫比乌斯反演)
		
题意:求(1,b)区间和(1,d)区间里面gcd(x, y) = k的数的对数(1<=x<=b , 1<= y <= d). 知识点: 莫比乌斯反演/*12*/ 线性筛求莫比乌 ...
 - BZOJ 2154: Crash的数字表格 [莫比乌斯反演]
		
2154: Crash的数字表格 Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 2924 Solved: 1091[Submit][Status][ ...
 - BZOJ2301: [HAOI2011]Problem b[莫比乌斯反演 容斥原理]【学习笔记】
		
2301: [HAOI2011]Problem b Time Limit: 50 Sec Memory Limit: 256 MBSubmit: 4032 Solved: 1817[Submit] ...
 - Bzoj2154 Crash的数字表格 乘法逆元+莫比乌斯反演(TLE)
		
题意:求sigma{lcm(i,j)},1<=i<=n,1<=j<=m 不妨令n<=m 首先把lcm(i,j)转成i*j/gcd(i,j) 正解不会...总之最后化出来的 ...
 - 莫比乌斯函数筛法 & 莫比乌斯反演
		
模板: int p[MAXN],pcnt=0,mu[MAXN]; bool notp[MAXN]; void shai(int n){ mu[1]=1; for(int i=2;i<=n;++i ...
 - 【BZOJ-2440】完全平方数      容斥原理 + 线性筛莫比乌斯反演函数 + 二分判定
		
2440: [中山市选2011]完全平方数 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2371 Solved: 1143[Submit][Sta ...
 - POI2007_zap      莫比乌斯反演
		
题意:http://hzwer.com/4205.html 同hdu1695 #include <iostream> #include <cstring> #include & ...
 - hdu.5212.Code(莫比乌斯反演 && 埃氏筛)
		
Code Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total Submi ...
 - CSU 1325 莫比乌斯反演
		
题目大意: 一.有多少个有序数对(x,y)满足1<=x<=A,1<=y<=B,并且gcd(x,y)为p的一个约数: 二.有多少个有序数对(x,y)满足1<=x<=A ...
 
随机推荐
- java:类集操作总结
			
java:类集操作总结 1.List接口允许有重复的元素,Set接口中不允许有重复的元素 2.ArrayList,和Vector的区别 3.set依靠equals和hashCode区分 4.TreeS ...
 - c# ListBox
			
1. ListBox用法(http://www.cnblogs.com/chinahbzm/articles/3577285.html) 2. ListBox使用(http://www.cnblogs ...
 - Android基于socket的群聊程序
			
在网上看了好多,但是感觉不是太简单就是只能单独聊,所以就自己写了个可以群聊的,直接上代码了 一.服务器端 这里用的MyEclipse作为服务器端 MyServerScoket.java package ...
 - HNOI2008玩具装箱 斜率优化
			
题目描述 P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1...N的N件玩具, ...
 - oracle数据库规划建议
			
之前负责的项目有用到oracle的,oracle dba给过一些建议,自己整理了一下,写再这里做个备忘 数据库需求分析: 1. 创建的数据库名称为maildb,并且字符集为UTF8. 2. 提供可连接 ...
 - CTSC2017 游记
			
Day0 从早上8点开始坐车 公交--火车--地铁--地铁--步行--打的. 下午3:30我们终于报道完毕来到了试机地点. 这电脑简直比学校的电脑高级的不知道哪里去了. 内存3.8G,,,学校就2G. ...
 - noip寻找道路
			
题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点连通. 2 .在满足条 ...
 - 在Debug中使用断点调试程序
			
我最近在学习汇编的程序,所以很多都需要动手写点代码去测试,如果是测试三五行代码的还比较简单,可以在debug中直接按T进行单步调试,但是到后来调试的代码越来越复杂,越来越长,如果再使用单步调试不知道要 ...
 - app专项测试(稳定性测试、安全性测试)
			
https://blog.csdn.net/xiaomaoxiao336368/article/details/84887948
 - hashcode和equals
			
Java中集合(Collection):一类是List另外一类是Set: 区别:list中元素有序,可重复 Set元素无序,不能重复 如何保证元素不重复呢?Object.Equals 但是当添加的元素 ...