/**
大意: 给定[a,b],[c,d] 在这两个区间内分别取一个x,y 使得 (x+y)%p = m
思路:res = f(b,d) -f(b,c-1)-f(a-1,d)+f(a-1,c-1); f(b,d ) 表示在[0,b],[0,d] 之间有多少个符合上述要求的数
1、将[0,b] 分为两部分, b/p 和 b%p 能整除p的[0,(b/p)*p] 和[(b/p)*p+1,b ] 同理[0,d]也可以这样分, 这样对于[0,b] [0,d ] 分别有两种情况,则一共有四种情况。
a、 对于能整除的部分,直接相乘可得结果ans += (b/p)*(d/p)*p;
b、 对于b 不能整除的和 d 能整除的。。 ans += (b%p+1)*(d/p)
c、 对于d不能整除的和b能整除的。 ans += (d%p+1)*(b/p)
d 、 对于 b不能整除和d也不能整除的。。
先举下面一个例子 对于一个完整的区间来说,不难想到[0,m]对应[m,0],那么对于[m+1,p-1]对应哪一个区间呢,一个数a来说,如果a%p=m,则a=m,m+p,m+2*p……由于[0,p-1]中任意两个数的和都小于2*p,因此a只能为m或者m+p,那么[m+1,p-1]就对应着[p-1,m-1]。下面是m=3,p=8的情况
0 1 2 3 4 5 6 7
3 2 1 0 7 6 5 4 那么。。ma = b%p mb = d%p。。。
若是ma〉m 那么:
ans += min(m+1,mb+1);
tmp = (p+m-ma)%p;
if(tmp<=mb) ans += (mb-tmp+1); 若是ma〈 m 那么:
tmp = (m-ma+p)%p;
if(tmp<=mb)
ans += min(m-tmp+1,mb-tmp+1);
**/
////////////////////////////////////////////////
别人的解释。。。
总的组合数很容易算出来,也就是两个区间的整数的个数的乘积。接下来是求两个数的和,对于一个区间,我们可以根据区间模p的结果进行划分:[a%p,p-],[,p-],[,b%p],也就是说把区间中前面和后面不完整的[,p-]的区间单独拿出来分析,中间的完整的一起算就好了。接下来是区间中模p等于m的数的个数,对于一个完整的区间来说,不难想到[,m]对应[m,],那么对于[m+,p-]对应哪一个区间呢,一个数a来说,如果a%p=m,则a=m,m+p,m+*p……由于[,p-]中任意两个数的和都小于2*p,因此a只能为m或者m+p,那么[m+,p-]就对应着[p-,m-]。下面是m=,p=8的情况 这样一个完整的区间中两个数的和对p取模等于m的对应关系就确定了。接下来就是分区间讨论,对于完整的区间可以完全对应,因此是p,对于不完整的区间,算出它对应的区间,然后跟另一个区间比较,看覆盖的长度就行了。这题想到这应该就没问题了,但是写起来还是挺容易错的。
//////////////////////////////////////////////// #include <iostream>
#include <algorithm>
using namespace std;
long long a,b,c,d,p,m; long long min(long long a,long long b){
return a<b?a:b;
} long long sol(long long b,long long d){
if(b<||d<)
return ;
long long ma,mb;
long long ans =;
long long tmp;
ans += (b/p)*(d/p)*p;
ma = b%p;
mb = d%p;
ans += (ma+)*(d/p) + (mb+)*(b/p);
if(ma>m){
ans += min(m+,mb+);
tmp = (p+m-ma)%p;
if(tmp<=mb) ans += (mb-tmp+);
}else{
tmp = (m-ma+p)%p;
if(tmp<=mb)
ans += min(m-tmp+,mb-tmp+);
}
return ans;
} long long gcd(long long a,long long b){
if(b==)
return a;
return gcd(b,a%b);
} int main()
{
int t;
cin>>t;
int cnt;
for(cnt=;cnt<=t;cnt++){
cin>>a>>b>>c>>d>>p>>m;
long long res;
res = sol(b,d)-sol(b,c-)-sol(a-,d)+sol(a-,c-);
long long sum =(long long ) ((b-a+)*(d-c+));
long long gcdD = gcd(res ,sum);
// cout<<res<<"------------>"<<sum<<endl;
res = res/gcdD;
sum = sum/gcdD;
cout<<"Case #"<<cnt<<": ";
cout<<res<<"/"<<sum<<endl;
}
return ;
}

hdu 4790 Just Random 神奇的容斥原理的更多相关文章

  1. HDU 4790 Just Random 数学

    链接:pid=4790">http://acm.hdu.edu.cn/showproblem.php?pid=4790 意:从[a.b]中随机找出一个数字x,从[c.d]中随机找出一个 ...

  2. HDU 4790 Just Random (2013成都J题)

    Just Random Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  3. hdu 4790 Just Random (2013成都J题) 数学思路题 容斥

    题意:在[a,b]  [c,d] 之间,和模p等于m的对数 详见代码 #include <stdio.h> #include <algorithm> #include < ...

  4. hdu 4790 Just Random (思路+分类计算+数学)

    Problem Description Coach Pang and Uncle Yang both love numbers. Every morning they play a game with ...

  5. hdu 4790 Just Random

    思路:对于a<=x<=b,c<=y<=d,满足条件的结果为ans=f(b,d)-f(b,c-1)-f(a-1,d)+f(a-1,c-1). 而函数f(a,b)是计算0<= ...

  6. hdoj 4790 Just Random 【数学】

    题目:hdoj 4790 Just Random 题意:给你两个闭区间[a,b],[c,d],分别从中等可能的跳出 x 和 y ,求(x+y)%p == m的概率 分析: 假如是[3,5] [4,7] ...

  7. HDU 4790:Just Random(容斥)

    Just Random Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total S ...

  8. Just Random HDU - 4790 思维题(打表找规律)分段求解

    Coach Pang and Uncle Yang both love numbers. Every morning they play a game with number together. In ...

  9. HDU 4336:Card Collector(容斥原理)

    http://acm.split.hdu.edu.cn/showproblem.php?pid=4336 Card Collector Special Judge Problem Descriptio ...

随机推荐

  1. CURD 例子

    public function modify(){ $id=$_GET['id']; $m=M('user'); $arr=$m->find($id); //var_dump($arr); $t ...

  2. Windows Latex 中日文字体设置例

    中文字体例: \documentclass[CJK]{article} \usepackage{CJKutf8} \newcommand{\songti}{\CJKfamily{song}} % 宋体 ...

  3. Uber在华从沸点到冰点 搞定这些才能继续走下去

    腾讯科技 蒋栩根 5月6日报道 五一前夕,本应坐等笑看小长假带来的喜人业绩的Uber被广州市工商.交委.公安部门的联合检查当头浇了一盆冷水,也被戴上了一顶“涉嫌非法运营”的帽子.而一天前,它才与广物汽 ...

  4. cpu亲和力总结taskset和setcpu及其他相关

    一:taskset -- 获取或指定进程运行的CPU. man taskset出现 CPU affinity is a scheduler property that "bonds" ...

  5. c#中常用的异常类型

    c#中异常捕获catch{}常用的异常类型 Exception 类   描述 SystemException 其他用户可处理的异常的基本类  ArgumentException 方法的参数是非法的  ...

  6. Hadoop-04-HBase全然分布式环境搭建

    Hbase分布式具体安装步骤 Hadoop全然分布式环境已经搭建完毕(參见01_Hadoop全然分布式环境搭建). 注意:Hbase和Hadoop的版本号必须相应! 不然会出现各种问题! 这里选用的是 ...

  7. 如何最简单的优化MySql

    1.创建索引,一定要根据实际情况来创建,如果是连接表查询,如一个主帐号连接多个子帐号,可以考虑两个或三个以上的多索引: 2.合理利用时间排序,由于大多数表格用时间来排序,数据量相当大的时候,在时间列上 ...

  8. 【MFC相关】MFC入门相关

    1.MFC的“匈牙利标识符命名法”,这是一个约定,可以增加代码的可读性: 声明或定义了一个类,那么这个类可以以“C”(class)为前缀,如CHelloWorldDlg类: 定义一个无符号型的局部变量 ...

  9. Android 开发笔记“程序安装包APK的制作”

    资源来源:http://blog.csdn.net/qualcent/article/details/6959547 完成Android项目后,需要将程序打包成APK文件(Android Packag ...

  10. 7.PHP 教程_PHP常量

    常量值被定义后,在脚本的其他任何地方都不能被改变. PHP常量 常量是一个简单值的标识符.该值在脚本中不能改变. 一个常量由英文字母.下划线.和数字组成,但数字不能作为首字母出现.(常量名不需要加$修 ...