给定两个数b,d,问[1,b]和[1,d]区间上有多少对互质的数。(x,y)和(y,x)算一个。

对于[1,b]部分,用欧拉函数直接求。对于大于b的部分,求n在[1,b]上有多少个互质的数,用容斥原理。

主要学习容斥原理的写法,本题使用DFS。容斥原理复杂度比较高,是指数复杂度。

输出长整型不能用lld,必须用I64d。

#include<stdio.h>
#include<iostream>
#include<stdlib.h>
#include<string.h>
#include<algorithm>
using namespace std;
typedef long long ll;
const int maxn = 1e5 + 7;
int a, b, c, d, k;
bool isPrime[maxn];
ll euler[maxn];
ll sumeuler[maxn];
int p[maxn][20], ps[maxn];
void initPrimes(){
memset(isPrime, 1, sizeof(isPrime));
for (int i = 1; i < maxn; i++){
euler[i] = i;
}
for (int i = 2; i < maxn; i++){
if (isPrime[i]){
for (int j = i; j < maxn; j += i){
isPrime[j] = false;
p[j][ps[j]++] = i;
euler[j] = euler[j] * (i - 1) / i;
}
}
}
sumeuler[1] = 1;
for (int i = 2; i < maxn; i++){
sumeuler[i] = sumeuler[i - 1] + euler[i];
}
}
ll dfs(int ind, int n, int x){//容斥原理核心代码
ll s = 0;
for (int i = ind; i < ps[x]; i++){
s += n / p[x][i] - dfs(i + 1, n / p[x][i], x);
}
return s;
}
ll huzhi(int n, int x){//0~n之间,与x互质的数字个数
return n - dfs(0, n, x);
}
int main(){
freopen("in.txt", "r", stdin);
initPrimes();
int caseCount;
scanf("%d", &caseCount);
for (int caseid = 1; caseid <= caseCount; caseid++){
scanf("%d%d%d%d%d", &a, &b, &c, &d, &k);
ll ans;
if (k == 0)
ans = 0;
else{
if (b > d)swap(b, d);
b /= k, d /= k;
ans = sumeuler[b];
for (int i = b + 1; i <= d; i++){
ans += huzhi(b, i);
}
}
printf("Case %d: %I64d\n", caseid, ans);
}
return 0;
}

容斥原理的另一种写法:

int calc(int n,int m)//n < m,求1-n内和m互质的数的个数
{
getFactors(m);
int ans = 0;
for(int i = 1;i < (1<<fatCnt);i++)
{
int cnt = 0;
int tmp = 1;
for(int j = 0;j < fatCnt;j++)
if(i&(1<<j))
{
cnt++;
tmp *= factor[j][0];
}
if(cnt&1)ans += n/tmp;
else ans -= n/tmp;
}
return n - ans;
}

容斥原理项的个数为2的幂次,肯定不会太大,所以一定可以用一个int来表示所有情况。

本题还可以用莫比乌斯反演来解决。

#include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
#include <set>
#include <map>
#include <string>
#include <math.h>
#include <stdlib.h>
#include <time.h>
using namespace std;
const int MAXN = 1e5 + 7;
typedef long long ll;
bool isprime[MAXN];
int prime[MAXN], psize;
int mu[MAXN];
ll euler[MAXN], sumeuler[MAXN];
void init(){
memset(isprime, false, sizeof(isprime));
mu[1] = euler[1] = sumeuler[1] = 1;
psize = 0;
for (int i = 2; i <= MAXN; i++) {
if (!isprime[i]) {
prime[psize++] = i;
mu[i] = -1;
euler[i] = i - 1;
}
for (int j = 0; j < psize&&i*prime[j] < MAXN; j++) {
isprime[i * prime[j]] = true;
if (i % prime[j] == 0) {
mu[i * prime[j]] = 0;
euler[i*prime[j]] = euler[i] * prime[j];
break;
}
else {
mu[i * prime[j]] = -mu[i];
euler[i*prime[j]] = euler[i] * (prime[j] - 1);
}
}
sumeuler[i] = sumeuler[i - 1] + euler[i];
}
}
ll eu(int b){
long long ans2 = 0;
for (int i = 1; i <= b; i++)
ans2 += (long long)mu[i] * (b / i)*(b / i);
return ans2;
}
void debug(){
for (int i = 1; i < MAXN; i++){
if (eu(i) / 2 != sumeuler[i] - 1)
cout <<i<<" "<< eu(i) / 2 << " " << sumeuler[i] - 1 << endl;
}
exit(0);
}
int main(){
freopen("in.txt", "r", stdin);
int T;
int a, b, c, d, k;
init();
//debug();
scanf("%d", &T);
int iCase = 0;
while (T--)
{
iCase++;
scanf("%d%d%d%d%d", &a, &b, &c, &d, &k);
if (k == 0) {
printf("Case %d: 0\n", iCase);
continue;
}
b /= k; d /= k;
if (b > d)swap(b, d);
long long ans1 = 0;
for (int i = 1; i <= b; i++)
ans1 += (long long)mu[i] * (b / i)*(d / i);
//这里ans2表示重复的部分,这部分可以用欧拉函数直接求,完全不需要for循环,但是提交却是wa,经过本机检测,完全没有问题
long long ans2 = 0;
for (int i = 1; i <= b; i++)
ans2 += (long long)mu[i] * (b / i)*(b / i);
ans1 -= ans2 / 2;
//ans1 -= (sumeuler[b] - 1);
printf("Case %d: %I64d\n", iCase, ans1);
}
return 0;
}

hdu1695 容斥原理 莫比乌斯反演的更多相关文章

  1. HDU1695 GCD(莫比乌斯反演)

    传送门 看了1个多小时,终于懂了一点了 题目大意:给n,m,k.求gcd(x,y) = k(1<=x<=n, 1<=y<=m)的个数 思路:令F(i)表示i|gcd(x,y)的 ...

  2. hdu1695(莫比乌斯反演)

    传送门:GCD 题意:求[1,n],[1,m]gcd为k的对数. 分析:莫比乌斯入反演门题,gcd(x,y)==k等价于gcd(x/k,y/k)==1,求出[1,n][1,m]互质的对数,在减去[1, ...

  3. BZOJ 2440 中山市选2011 全然平方数 二分答案+容斥原理+莫比乌斯反演

    题目大意:求第k个无平方因子数是多少(无视原题干.1也是全然平方数那岂不是一个数也送不出去了? 无平方因子数(square-free number),即质因数分解之后全部质因数的次数都为1的数 首先二 ...

  4. hdu1695 GCD 莫比乌斯反演做法+枚举除法的取值 (5,7),(7,5)看做同一对

    /** 题目:hdu1695 GCD 链接:http://acm.hdu.edu.cn/status.php 题意:对于给出的 n 个询问,每次求有多少个数对 (x,y) , 满足 a ≤ x ≤ b ...

  5. BZOJ2005: [Noi2010]能量采集(容斥原理 莫比乌斯反演)

    Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 4727  Solved: 2877[Submit][Status][Discuss] Descript ...

  6. [HAOI2011][bzoj2301] Problem b [莫比乌斯反演+容斥原理+分块前缀和优化]

    题面: 传送门 有洛谷就尽量放洛谷链接呗,界面友好一点 思路: 和HDU1695比较像,但是这一回有50000组数据,直接莫比乌斯反演慢慢加的话会T 先解决一个前置问题:怎么处理a,c不是1的情况? ...

  7. BZOJ2301: [HAOI2011]Problem b[莫比乌斯反演 容斥原理]【学习笔记】

    2301: [HAOI2011]Problem b Time Limit: 50 Sec  Memory Limit: 256 MBSubmit: 4032  Solved: 1817[Submit] ...

  8. 【BZOJ-2440】完全平方数 容斥原理 + 线性筛莫比乌斯反演函数 + 二分判定

    2440: [中山市选2011]完全平方数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2371  Solved: 1143[Submit][Sta ...

  9. hdu1695 莫比乌斯反演

    莫比乌斯反演:可参考论文:<POI XIV Stage.1 <Queries>解题报告By Kwc-Oliver> 求莫比乌斯函数mu[i]:(kuangbin模板) http ...

随机推荐

  1. Intel® Core™ i5-5300U Processor

    3M Cache, up to 2.90 GHz Specifications Ordering and Compliance Essentials     Product Collection 5t ...

  2. python异常信息获取

    1.python调试的时候获取异常信息 import traceback print '######################################################## ...

  3. 第十七章 springboot + devtools(热部署)

    技术介绍 devtools:是boot的一个热部署工具,当我们修改了classpath下的文件(包括类文件.属性文件.页面等)时,会重新启动应用(由于其采用的双类加载器机制,这个启动会非常快,如果发现 ...

  4. 《Linux总线、设备与驱动》USB设备发现机制

    说明:本分析基于mstar801平台Linux2.6.35.11内核,其他内核版本仅供参考. 一.程序在内核中的位置 1.usb host做为pci总线下的一个设备存在(嵌入式系统中有可能也会直接挂在 ...

  5. C#读写txt文件的两种方法介绍[转]

    C#读写txt文件的两种方法介绍 1.添加命名空间 System.IO; System.Text; 2.文件的读取 (1).使用FileStream类进行文件的读取,并将它转换成char数组,然后输出 ...

  6. Cognos访问权限之让拒绝更友善

    关于cognos的访问权限之前我也做了不少总结,但是由于时间关系加上用户也只要实现功能就好,我们做的效果就是像很多人一样,就那样就好了.但是有很多事情,只要你肯动脑筋,你会发现,你还可以做的更好,下面 ...

  7. cognos report同比环比以及默认为当前月分析

    现在的需求是按月份分析不同时期的余额数据,.(报表工具:cognos report:建模工具:FM) ------------------------------------------------- ...

  8. 6. Activity life cycle

    An activity can exist in essentially three states: Resumed The activity is in the foreground of the ...

  9. Java 强引用、 软引用、 弱引用、虚引用

     1.对象的强.软.弱和虚引用 在JDK 1.2曾经的版本号中.若一个对象不被不论什么变量引用,那么程序就无法再使用这个对象. 也就是说,仅仅有对象处于可触及(reachable)状态.程序才干使 ...

  10. js的正则匹配 和 blur

    <script type="text/javascript" src="http://code.jquery.com/jquery-1.10.2.min.js&qu ...