“浪潮杯”第九届山东省ACM大学生程序设计竞赛 F: Four-tuples容斥定理
题目
F : Four-tuples

输入
1
1 1 2 2 3 3 4 4
输出
1
题意
给l1, r1, l2, r2, l3, r3, l4, r4 , 八个数据, 要求输出在区间[l1, r1] , [l2, r2] , [l3, r3] , [l4, r4]
(记为A, B, C, D )范围内, 各取一个数(取作x1, x2, x3, x4), 并且x1 != x2, x2 != x3, x3 != x4, x4 != x1,
)范围内, 各取一个数(取作x1, x2, x3, x4), 并且x1 != x2, x2 != x3, x3 != x4, x4 != x1,
注意像x1 == x3是可以的
思路
容斥原理
结果 = 每个区间值的个数相乘 - 四种相等的情况即x1=x2, x2=x3...... (前者好说, 关键是后面这部分)
四种相等的情况计算方法:(ABCD代表四个区间里的任意一个数)

AC代码
#include <bits/stdc++.h>
#include <algorithm> using namespace std; const int mod = 1e9 + 7; typedef long long ll; ll query2(ll l1, ll r1, ll l2, ll r2)//query求的是几个区间重复的数的个数, 以下也是
{
ll l = max(l1, l2), r = min(r1, r2);
return r-l+1>0? r-l+1 : 0;
}
ll query3(ll l1, ll r1, ll l2, ll r2, ll l3, ll r3)
{
ll l = max(l1, max(l2, l3)), r = min(r1, min(r2, r3));
return r-l+1>0? r-l+1 : 0;
}
ll query4(ll l1, ll r1, ll l2, ll r2, ll l3, ll r3, ll l4, ll r4)
{
ll l = max(max(l3, l4), max(l1, l2)), r = min(min(r3, r4), min(r1, r2));
return r-l+1>0? r-l+1 : 0;
} int main()
{
int t;
ll l1, l2, l3, l4, r1, r2, r3, r4;
cin >> t;
while( t --)
{
scanf("%lld%lld%lld%lld%lld%lld%lld%lld", &l1,&r1,&l2,&r2,&l3,&r3,&l4,&r4); ll len1 = r1 - l1 + 1;
ll len2 = r2 - l2 + 1;
ll len3 = r3 - l3 + 1;
ll len4 = r4 - l4 + 1; ll sum = len1 * len2 % mod;
sum = sum * len3 % mod;
sum = sum * len4 % mod; ll ant = 0;
ant = (ant + query2(l1, r1, l2, r2) % mod * len3 % mod * len4 % mod) % mod;
ant = (ant + query2(l2, r2, l3, r3) % mod * len1 % mod * len4 % mod) % mod;
ant = (ant + query2(l4, r4, l3, r3) % mod * len1 % mod * len2 % mod) % mod;
ant = (ant + query2(l4, r4, l1, r1) % mod * len2 % mod * len3 % mod) % mod;
// 第一步完成--------------------------------------------------------- ant = (ant - query3(l1, r1, l2, r2, l3, r3) % mod * len4 % mod + mod) % mod;
ant = (ant - query3(l1, r1, l2, r2, l4, r4) % mod * len3 % mod + mod) % mod;
ant = (ant - query3(l4, r4, l2, r2, l3, r3) % mod * len1 % mod + mod) % mod;
ant = (ant - query3(l1, r1, l4, r4, l3, r3) % mod * len2 % mod + mod) % mod;
// 第二步完成--------------------------------------------------------- ant = (ant - query2(l1, r1, l2, r2) % mod * query2(l4, r4, l3, r3) % mod + mod) % mod;
ant = (ant - query2(l2, r2, l3, r3) % mod * query2(l4, r4, l1, r1) % mod + mod) % mod;
// 第三步完成--------------------------------------------------------- ant = (ant + 3 * query4(l1, r1, l2, r2, l3, r3, l4, r4) % mod + mod) % mod;
// 第四步完成--------------------------------------------------------- cout << (sum - ant + mod) % mod << endl;
} return 0;
}
“浪潮杯”第九届山东省ACM大学生程序设计竞赛 F: Four-tuples容斥定理的更多相关文章
- “浪潮杯”第九届山东省ACM大学生程序设计竞赛重现赛 C-Cities
		题目描述:There are n cities in Byteland, and the ith city has a value ai. The cost of building a bidirec ... 
- “浪潮杯”第九届山东省ACM大学生程序设计竞赛(重现赛)E.sequence(树状数组求逆序对(划掉))
		传送门 E.sequence •题意 定义序列 p 中的 "good",只要 i 之前存在 pj < pi,那么,pi就是 "good": 求删除一个数, ... 
- 第八届山东省ACM大学生程序设计竞赛个人总结
		因为省赛,从开学紧张到5月7号.心思也几乎全放在ACM的训练上.因为我还是校台球协会的会长,所以台协还有一些事情需要忙,但是我都给延迟了.老会长一直在催我办校赛,但我一直说 等等吧,因为校赛只能在周六 ... 
- 2014年山东省第五届ACM大学生程序设计竞赛F题:Full Binary Tree
		题目描述 In computer science, a binary tree is a tree data structure in which each node has at most two ... 
- 山东省第四届ACM大学生程序设计竞赛解题报告(部分)
		2013年"浪潮杯"山东省第四届ACM大学生程序设计竞赛排名:http://acm.upc.edu.cn/ranklist/ 一.第J题坑爹大水题,模拟一下就行了 J:Contes ... 
- [2012山东省第三届ACM大学生程序设计竞赛]——n a^o7 !
		n a^o7 ! 题目:http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2413 Time Lim ... 
- [2012山东省第三届ACM大学生程序设计竞赛]——Mine Number
		Mine Number 题目:http://acm.sdut.edu.cn/sdutoj/problem.php? action=showproblem&problemid=2410 Time ... 
- Alice and Bob(2013年山东省第四届ACM大学生程序设计竞赛)
		Alice and Bob Time Limit: 1000ms Memory limit: 65536K 题目描述 Alice and Bob like playing games very m ... 
- 2013年山东省第四届ACM大学生程序设计竞赛-最后一道大水题:Contest Print Server
		点击打开链接 2226: Contest Print Server Time Limit: 1 Sec Memory Limit: 128 MB Submit: 53 Solved: 18 [Su ... 
随机推荐
- Linux内核升级修复系统漏洞-RHSA-2017:2930-Important: kernel security and bug fix update
			公司使用的阿里云服务器(Centos7.4 x86_64bit)内核版本为:3.10.0-693.21.1.el7.x86_64, 2019年3月4日 02:07:58通过云盾安骑士-->漏洞管 ... 
- 题解0004:单词接龙(洛谷P1019)
			题目描述:已知一组单词,给定一个开头的字母,要求出以这个字母开头的最长的"龙"(每个单词都最多在"龙"中出现两次),在两个单词相连时,其重合部分合为一部分. 题 ... 
- zookeeper从小白到精通
			目录 1.介绍 1.1概念 1.2特点 1.3主要的集群步骤 1.4数据结构 1.5应用场景 2.本地安装 2.1安装jdk 2.2下载安装 2.3配置文件修改 2.4启动服务端 2.5启动客户端 2 ... 
- IDEA 配置Tomcat乱码解决方法
			问题:页面没有乱码,但是通过http请求的js文件会乱码,原因是由于 CharacterEncodingFilter 只会处理Servlet请求,不会处理静态文件的响应编码,所以这里需要进一步的配置. ... 
- 如何给Spring 容器提供配置元数据?
			这里有三种重要的方法给Spring 容器提供配置元数据. XML配置文件. 基于注解的配置. 基于java的配置. 
- Mosquitto安装和使用
			Mosquitto是一个实现了MQTT3.1协议的代理服务器,由MQTT协议创始人之一的Andy Stanford-Clark开发,它为我们提供了非常棒的轻量级数据交换的解决方案. 下载地址是: ht ... 
- 面试问题之数据结构与算法:map与unordered_map
			转载于:https://blog.csdn.net/u011475134/article/details/75810085 map map是STL的一个关联容器,它提供一对一数据处理能力.map内部自 ... 
- 面试问题之C++语言:说一说C++中四种cast转换
			C++中四种类型转换是:static_cast.dynamic_cast.const_cast.reinterpret_cast 1.const_cast 常量转换,用于将const变量转为非cons ... 
- Python form...import...和import的区别(自己理解的)
			Python有两种导入包和模块的方式,区别如下 form...import... import 相对导包 导入不同包子模块 可以导入模块所需变量/函数/类 init文件的__all__特殊变量(模 ... 
- js获取元素本身相关值
			Element.getBoundingClientRect()方法返回元素的大小及其相对于视口的位置. getClientRects() 方法返回的一组矩形的集合, 即:是与该元素相关的CSS 边框集 ... 
