二进制枚举+容斥原理+中国剩余定理

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std; #define MAXN 20
typedef long long LL; int n;
int s[MAXN];
LL a[MAXN], m[MAXN]; //a是余数,m是除数 LL extented_gcd(LL a,LL b, LL &x, LL &y) //扩展欧几里得
{
if(a == 0 && b == 0) return -1;
if(b == 0){
x = 1; y = 0; return a;
}
LL d = extented_gcd(b, a%b, y, x);
y -= a/b*x;
return d;
} LL mult(LL a, LL k, LL m){ //快速乘法
LL res = 0;
while(k){
if(k & 1LL) res = (res + a) % m;
k >>= 1;
a = (a << 1) % m;
}
return res;
} //x = ai(mod mi) mi之间互素
//M = m1 * m2 * ... * mi
//Mi'*Mi = 1 (mod mi) Mi = M/mi
//x = sigma(ai * Mi * M') % M
LL CRT(LL l, LL r) //中国剩余定理
{
LL M = 1, ans = 0;
for (int i = 0; i <= n; ++i)
if(s[i]) M *= m[i];
for(int i = 0;i <= n;i++)
{
if(s[i]){
LL Mi = M/m[i];
LL x,y;
extented_gcd(Mi, m[i], x,y); //求Mi*x=1(mod m[i])
x = (x%m[i] + m[i]) % m[i];
ans = (ans+mult(a[i]*Mi % M, x, M)) % M; //计算最小解
}
}
return (r+M-ans)/M - (l-1+M-ans)/M; //计算[l,r]间解的个数
} int main()
{
//freopen("in", "r", stdin);
int T, cas = 0;
scanf("%d", &T);
while(T--){
LL l, r;
scanf("%d%lld%lld", &n, &l, &r);
memset(s, 0, sizeof(s));
m[n] = 7; a[n] = 0; s[n] = 1;
for(int i = 0;i < n;i++)
scanf("%lld%lld", &m[i], &a[i]);
LL ans = 0;
int all = 1 << n;
for(int i = 0;i < all;i++){ //二进制枚举同余方程
int t = i, k = 0;
for(int j = 0;j < n;j++){
s[j] = t & 1;
t >>= 1;
k += s[j]; //计算同余方程个数
}
k = k & 1 ? -1 : 1;//容斥定理-奇减偶加
ans += 1LL * k * CRT(l, r);
}
printf("Case #%d: %lld\n", ++cas, ans);
}
return 0;
}

ACM/ICPC 之 中国剩余定理+容斥原理(HDU5768)的更多相关文章

  1. HDU 5768:Lucky7(中国剩余定理 + 容斥原理)

    http://acm.hdu.edu.cn/showproblem.php?pid=5768 Lucky7 Problem Description   When ?? was born, seven ...

  2. Hdu 5446 Unknown Treasure (2015 ACM/ICPC Asia Regional Changchun Online Lucas定理 + 中国剩余定理)

    题目链接: Hdu 5446 Unknown Treasure 题目描述: 就是有n个苹果,要选出来m个,问有多少种选法?还有k个素数,p1,p2,p3,...pk,结果对lcm(p1,p2,p3.. ...

  3. 【中国剩余定理】【容斥原理】【快速乘法】【数论】HDU 5768 Lucky7

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5768 题目大意: T组数据,求L~R中满足:1.是7的倍数,2.对n个素数有 %pi!=ai  的数 ...

  4. HDU 5768 Lucky7 (容斥原理 + 中国剩余定理 + 状态压缩 + 带膜乘法)

    题意:……应该不用我说了,看起来就很容斥原理,很中国剩余定理…… 方法:因为题目中的n最大是15,使用状态压缩可以将所有的组合都举出来,然后再拆开成数组,进行中国剩余定理的运算,中国剩余定理能够求出同 ...

  5. Lucky 7 (容斥原理 + 中国剩余定理)

    题意:求满足7的倍数,不满足其他条件num % p == a 的num的个数. 思路:利用中国剩余定理我i们可以求出7的倍数,但是多算了不满足约定条件又得减去一个,但是又发现多减了,又得加回来.如此, ...

  6. HDU 5768 Lucky7 容斥原理+中国剩余定理(互质)

    分析: 因为满足任意一组pi和ai,即可使一个“幸运数”被“污染”,我们可以想到通过容斥来处理这个问题.当我们选定了一系列pi和ai后,题意转化为求[x,y]中被7整除余0,且被这一系列pi除余ai的 ...

  7. HDU 5446 中国剩余定理+lucas

    Unknown Treasure Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Other ...

  8. HDU 5768 Lucky7 (中国剩余定理 + 容斥 + 快速乘法)

    Lucky7 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5768 Description When ?? was born, seven crow ...

  9. HDU 5768 Lucky7 (中国剩余定理+容斥)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5768 给你n个同余方程组,然后给你l,r,问你l,r中有多少数%7=0且%ai != bi. 比较明显 ...

随机推荐

  1. rank()函数的使用

    排序: ---rank()over(order by 列名 排序)的结果是不连续的,如果有4个人,其中有3个是并列第1名,那么最后的排序结果结果如:1 1 1 4select scoreid, stu ...

  2. time step和采样频率的关系

    当前的采样频率为11025HZ,overlap=0.5,取的是1024个采样点为1帧.则time step为256时的时间长度为11秒.即以11秒为单位分割原始的音频,生成一张语普图. >> ...

  3. 一次sql注入中转

    今天一朋友丢过来一个注入让我看看 url:http://xxxx/ 先看下页面 常规测试一下 用户名输入:' or 1=1 -- - 密码任意 返回 用户名输入:' or 1=2 -- - 返回 基本 ...

  4. 记lrd的高二上学期第五次调研考试

    河北某某中学的调研考试其实是很好玩的经历呢.可惜没有太多机会了. 背景: NOIP2016回来之后没有好好学文化课-.自习能翘就翘了,衡中特产学案自助没有好好写(说来我好像从来没被老师查到过,上课写学 ...

  5. C# Winform防止一个程序重复运行

    1: //在写一些服务型的软件的时候,你可能不希望一个操作系统里有两个副本在运行,这样也许会扰乱你的操作.这时,你就需要限制程序的副本.下面的这个方法,很简单的就可以实现上述功能. using Sys ...

  6. 2016福州大学软件工程第五、六次团队作业-Alpha阶段成绩汇总

    1.本次作业成绩统计结果: 本次Alpha阶段团队作业公布如下: 表格说明: PE:贡献百分比 YS:演示评分(满分15分) BK:博客评分(满分15分) SH:事后诸葛亮环节(满分5分) P:个人分 ...

  7. 五、基于hadoop的nginx访问日志分析--userAgent和spider

    useragent: 代码(不包含蜘蛛): # cat top_10_useragent.py #!/usr/bin/env python # coding=utf-8 from mrjob.job ...

  8. JS数组经典冒泡排序

    将8,4,3,1,4,6,等数字按照从小到大的顺序依次输出: var arr=new Array(); arr.push(8); arr.push(4); arr.push(3); arr.push( ...

  9. 解决Myeclipse PermGen space问题

    myeclipse配置web服务器配置 Window—Preferences—Myeclipse—Servers—tomcat JDK的Optional Java VM arguments配置为:-X ...

  10. vs插件ZunKoIDE

    →〇,配置: vs →壹,默认背景图路径 C:\Users\{用户名}\AppData\Local\Microsoft\VisualStudio\14.0\Extensions\gqyswd1b.dv ...