【神仙题】【P4885】 灭顶之灾
Description
请将题目名称的首字母连起来读
Scarlet有一张$n*m$的神秘表格。现在Scarlet向表格中填数字,她会从第一行中的某个格子起,按照从左往右,从上往下的顺序依次填写从$1$开始的正整数,直至填满最后一行。
为了让你确定这个表格,Scarlet会告诉你表格中的$s$组同行连续数字。之后,Scarlet会对你发起$q$次询问,你需要依次回答每个数字被填在第几行第几列中。
Input
第一行$4$个正整数分别代表$n,m,s,q$
接下来$s$行,每行两个正整数$a_i,b_i$,代表整数$a_i$到$b_i$在表格中处于同一行且连续
接下来$q$行,每行一个正整数$A_i$,表示每个询问的数字
Output
如果符合数据的表格不存在,输出一行“Impossible!”(不含引号)
再如果符合数据的表格不唯一,输出一行"Uncertain!"(不含引号)
否则输出$q$行,每行两个正整数,代表每个被询问的数字被填在第几行第几列,如果该数字不在表格内,输出"0 0"
Scarlet为了减小输出文件,以轻易地上传测试数据至服务器,她现在只需要你输出所有行列数据的异或和(包括前文的“0 0”)。
Sample Input
3 4 2 2
8 9
2 4
9
3
Sample Output
7
Hint
对于100%的数据,$1\leq n,m,A_i,a_i,b_i\leq 10^{18}$,$1\leq s,q\leq 5*10^5$,$0\leq b_i-a_i\leq m-1$
Solution
推式子……瞎搞……想明白细节还是很恶心……
考虑对于每一个形如\(a,b\)在同一行的信息,都提供了一个\(a\)所能出现的区间。具体的,考虑在一列中,\(a\)最靠左能出现在第\(1\)行,最靠右能出现在第\(m-(b-a)\)行(此时\(b\)在第\(m\)行)。如果从左向右,从上向下数,设\(1\)前面有\(x\)个\(0\),那么\(a\)是矩阵中第\(a+x\)个数。这就给出了我们一个方程:
\]
将\(a\)移项,化简可得:
\]
由此可以解出x的值。
显然分别对于所有的信息解方程,最后留下的\(x\)就是\(x\)能取到的值。当这个值的个数为\(0\)时无解,大于\(1\)时有多组解(矩阵不唯一)
考虑对于每个解集如何求交。
由于是一个模意义下的解,\(x\)的解集共有两种情况,第一种情况形如\(x~\in~[l,r]\),第二种情况形如\(x~\in~[0,l]~\bigcup~[r,m-1]\)。对于第一种情况显然可以直接对每个解集求交。考虑第二种情况,能否通过单独维护左右两个区间的交集,最后与第一种情况分别相交再取并集得到答案呢?事实上是不能的。考虑如图的解集:

其中解1、2、3分别是解不等式得到的解集区间。显然他们的交集是被红色区域框柱的一部分。如果对左右部分分别求交,得到的区间会是绿色线段。再与解3求交后求并的结果是空集。答案错误。
正确的姿势应该是对每个解维护补集的并集。最后对并集求补集,所有解的交集。如果您不能理解上面的话,请多读几遍画个图。维护答案的方法使用数组存储并集即可,然后按照左端点排序,扫描一遍数组,对于覆盖线段树数为\(0\)的区间累加ans即可得到答案。
对于目前的数据这样的代码交上去即可AC。但是需要注意的是这样的算法存在瑕疵。考虑下面的数据:
2 2 2 1
4 4
2 3
1
正确答案显然应该输出\("Impossible!"\)
但事实上对于一部分代码这样的数据会输出一个答案3。输出x的解集你会发现计算机算出来的矩阵长这样:
0 1
2 3
4 5
这显然是不合法的,因为他的行数不合要求。但是我们在计算矩阵的时候并没有考虑行数的限制。解决方法很简单,对于所有一定出现在最后一行的数字(即\(b~\geq (n-1)~\times~m\)),对\(x\)的范围再做一个限制。具体的,设\(t=n~\times~m~-b\),则一定不会有大于\(t\)个\(0\)出现,添加限制\(x~\leq~t\)即可。在代码中,因为我脑子有毛病,所以用了另一个计算这个限制的方法,十分脑残但是懒得改了= =。
由此计算出的\(x\),便可作为正确的答案。
Code
在实现中,因为两个1e18相乘会爆long long,\((n-1)~\times~m\)使用int128存储。
#include<cstdio>
#include<cstdlib>
#include<algorithm>
#define rg register
#define ci const int
#define cl const long long int
typedef long long int ll;
namespace IO {
char buf[90];
}
template<typename T>
inline void qr(T &x) {
char ch=getchar(),lst=' ';
while(ch>'9'||ch<'0') lst=ch,ch=getchar();
while(ch>='0'&&ch<='9') x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
if(lst=='-') x=-x;
}
template<typename T>
inline void write(T x,const char aft,const bool pt) {
if(x<0) x=-x,putchar('-');
int top=0;
do {
IO::buf[++top]=x%10+'0';
x/=10;
} while(x);
while(top) putchar(IO::buf[top--]);
if(pt) putchar(aft);
}
template<typename T>
inline T mmax(const T a,const T b) {if(a>b) return a;return b;}
template<typename T>
inline T mmin(const T a,const T b) {if(a<b) return a;return b;}
template<typename T>
inline T mabs(const T a) {if(a<0) return -a;return a;}
template<typename T>
inline void mswap(T &a,T &b) {
T temp=a;a=b;b=temp;
}
const int maxn = 1000010;
struct Zay {
ll x;int y;
inline bool operator<(const Zay &_others) const {
return this->x < _others.x;
}
};
Zay MU[maxn];
ll n,m,ans,cnt;
int s,q;
__int128 uc,tp;
ll check();
int main() {
qr(n);qr(m);qr(s);qr(q);
rg ll a,b,l1=0,r1=m-1;
uc=n-1;uc*=m;
while(s--) {
a=b=0;qr(a);qr(b);
if((1.0*b)/n > (1.0*m)) {puts("Impossible!");return 0;}
a%=m;
ll tl=((1ll-a)%m+m)%m,tr=((m-b)%m+m)%m;
if(tl <= tr) l1=mmax(l1,tl),r1=mmin(r1,tr);
else {
MU[++cnt]=(Zay) {tr+1,1};
MU[++cnt]=(Zay) {tl-1,-1};
}
tp=b;
if(tp > uc) {MU[++cnt]=(Zay) {m-(int)(tp-uc)+1,1};MU[++cnt]=(Zay) {m+1,-1};}
}
MU[++cnt]=(Zay) {-1,1};MU[++cnt]=(Zay) {l1-1,-1};MU[++cnt]=(Zay) {r1+1,1};MU[++cnt]=(Zay) {m+1,-1};
rg ll k;
std::sort(MU+1,MU+1+cnt);
k=check();
while(q--) {
a=0;qr(a);
a+=k;
if((1.0*a/n) > 1.0*m) continue;
ll _temp=(a-1)/m+1;ans^=_temp;
_temp=(a-1)%m+1;
ans^=_temp;
}
write(ans,'\n',true);
return 0;
}
ll check() {
rg ll k,sum=0,tg=0,i=1,tl=-2;
while(i <= cnt) {
if(tg <= 0) sum+=MU[i].x-1-tl,k=tl;
tl=MU[i].x;
while((i <= cnt) && (MU[i].x == tl)) tg+=MU[i].y,++i;
}
if(!sum) {puts("Impossible!");exit(0);}
else if(sum > 1) {puts("Uncertain!");exit(0);}
else return k+1;
}
Summary
多个区间的交难以维护,可以考虑维护区间补集的并集,最后求补集即为交集。
【神仙题】【P4885】 灭顶之灾的更多相关文章
- 【BZOJ5285】[HNOI2018]寻宝游戏(神仙题)
[BZOJ5285][HNOI2018]寻宝游戏(神仙题) 题面 BZOJ 洛谷 题解 既然是二进制按位的运算,显然按位考虑. 发现这样一个关系,如果是\(or\)的话,只要\(or\ 1\),那么无 ...
- 【BZOJ5213】[ZJOI2018]迷宫(神仙题)
[BZOJ5213][ZJOI2018]迷宫(神仙题) 题面 BZOJ 洛谷 题解 首先可以很容易的得到一个\(K\)个点的答案. 构建\(K\)个点分别表示\(mod\ K\)的余数.那么点\(i\ ...
- 【BZOJ1071】[SCOI2007]组队(神仙题)
[BZOJ1071][SCOI2007]组队(神仙题) 题面 BZOJ 洛谷 题解 首先把式子整理一下,也就是\(A*h+B*v\le C+A*minH+B*minV\) 我们正常能够想到的做法是钦定 ...
- 【agc006f】Blackout(神仙题)
[agc006f]Blackout(神仙题) 翻译 给定一个\(n*n\)的网格图,有些格子是黑色的.如果\((x,y),(y,z)\)都是黑色的,那么\((y,x)\)也会被染黑,求最终黑格子数量. ...
- 【BZOJ3244】【NOI2013】树的计数(神仙题)
[BZOJ3244][NOI2013]树的计数(神仙题) 题面 BZOJ 这题有点假,\(bzoj\)上如果要交的话请输出\(ans-0.001,ans,ans+0.001\) 题解 数的形态和编号没 ...
- 【bzoj2118&洛谷P2371】墨墨的等式(最短路神仙题)
题目传送门:bzoj2118 洛谷P2371 这道题看了题解后才会的..果然是国家集训队的神仙题,思维独特. 首先若方程$ \sum_{i=1}^{n}a_ix_i=k $有非负整数解,那么显然对于每 ...
- P3202 [HNOI2009]通往城堡之路 神仙题
这个题不是坑人吗...写个tarjan标签,然后拿这么个神仙题来搞...代码有点看不懂,有兴趣的可以去洛谷题解区看看,懒得想了. 题干: 题目描述 听说公主被关押在城堡里,彭大侠下定决心:不管一路上有 ...
- Codeforces & Atcoder神仙题做题记录
鉴于Codeforces和atcoder上有很多神题,即使发呆了一整节数学课也是肝不出来,所以就记录一下. AGC033B LRUD Game 只要横坐标或者纵坐标超出范围就可以,所以我们只用看其中一 ...
- UOJ #460. 新年的拯救计划 神仙题+构造
对于这个神仙题,我还能说什么~ 第一个答案=$n/2$ 还是比较好猜的. 对于构造这个树,大概就是先从 $1$ 号节点向 $n/2$ 距离以内都连一条边,再在第 $n/2$ 个节点进行这个操作,然后从 ...
- Codeforces 464E The Classic Problem(主席树+最短路+哈希,神仙题)
题目链接 题意:给出一张 \(n\) 个点 \(m\) 条边的无向图,第 \(i\) 条边连接 \(u_i,v_i\),边权为 \(2^{w_i}\),求 \(s\) 到 \(t\) 的最短路. \( ...
随机推荐
- Codeforces Round #495 (Div. 2) Sonya and Matrix
正常没有正方形的限制下,值为i的点个数4i 那么从0开始遍历,第一个不为4i的值就是min(x, y) 由于对称性我们姑且令x为这个值 我们先列举n*m=t的各种情况 对于一对n, m.我们已经知道n ...
- 编写你自己的Python模块
其实网上Python教程挺多的,编写你自己的模块很简单,这其实就是你一直在做的事情!这是因为每一个 Python 程序同时也是一个模块.你只需要保证它以 .py 为扩展名即可.下面的案例会作出清晰的解 ...
- 手把手教你封装 Vue 组件,并使用 npm 发布
Vue 开发插件 开发之前先看看官网的 开发规范 我们开发的之后期望的结果是支持 import.require 或者直接使用 script 标签的形式引入,就像这样: // 这里注意一下包的名字前缀是 ...
- 【MySQL解惑笔记】Navicat 无法远程连接MySQL数据库
安装好Navicat之后远程连接MySQL数据库出现以下报错截图: 出现以上截图怀疑是mysql用户权限不够: GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.1 ...
- 蓝桥杯算法训练 区间k大数查询
算法训练 区间k大数查询 问题描述 给定一个序列,每次询问序列中第l个数到第r个数中第K大的数是哪个. 输入格式 第一行包含一个数n,表示序列长度. 第二行包含n个正整数,表示给定的序列. 第三个 ...
- python读取日志,存入mysql
1.从 http://www.almhuette-raith.at/apache-log/access.log 下载 1万条日志记录,保存为一个文件,读取文件并解析日志,从日志中提取ip, time_ ...
- LeetCode - 463. Island Perimeter - O(MN)- (C++) - 解题报告
原题 原题链接 You are given a map in form of a two-dimensional integer grid where 1 represents land and 0 ...
- 深入理解eos账户体系 active和action
在eos中,账户是一个非常重要的概念. 账户分为两部分组成 一种是active 一种是action. 智能合约本质上来讲就是一个action加上一个回馈脚本程序.任何智能合约都有这俩个部分组成. 那么 ...
- Twaver的mono-desiner导出的json文件解析
以画的交换机为例,其他大概都差不多. 利用Twaver做出交换机模型如图1所示,其中,每一个端口都是一个单独的对象.具体Twaver操作流程参见网址:http://twaver.servasoft.c ...
- 安装Tensorflow过程pip安装报错:is not a supported wheel on this platform
安装Tensorflow过程pip安装报错:is not a supported wheel on this platform 通过pip安装wheel镜像时,安装指令为: pip install - ...