codeforces706E
好精妙的一道题啊
传送门:here
大致题意:有一个$ n*m$的矩阵,q次询问每次交换给定两个无交矩阵的对应元素,求操作后的最终矩阵?
数据范围:$ n,m<=1000, q<=10000$
模拟赛的时候考到类似的,当时很快想到对每行维护一个$ treap/splay$的优秀做法,
然后感觉复杂度一千万$ *log$甚至比暴力慢(事实证明确实如此)
正解其实又好写又快速,不过对我这种数据结构做傻的菜鸡来说考场上确实是想不到啊....
$ solution:$
对于每个元素维护两个指针R(右边的那个元素标号)以及D(下边的那个元素标号)还有这个点的元素值
注意元素从$ (0,0)$开始记录
对于每次修改,会发现只有矩阵边缘的点的指针需要被修改(如图所示)

交换红蓝两个矩形时,只有涂黄色的格子下指针需要修改,涂绿色的格子右指针需要修改,对应swap一下即可
容易发现每次修改只有$ 2n+2m$格被修改了,因此总复杂度为$ O((n+m)q)$,非常优秀
(注意存图的时候第一行和第一列要空出来给空元素)
代码理解之后非常好写,以下是我的代码
#include<cstdio>
#include<iostream>
#define rt register int
using namespace std;
int i,j,k,m,n,x,y,z,cnt,p;
struct node{
int v,D,R;//D表示下,R表示右
}a[];
int main(){
scanf("%d %d %d",&n,&m,&k);n++;m++;
for(rt i=;i<=n;i++)
for(rt j=;j<=m;j++){
int v=(i-)*m+j;
if(i>&&j>)scanf("%d",&a[v].v);
if(i!=n)a[v].D=v+m;
if(j!=m)a[v].R=v+;
}
while(k--){
int X1,Y1,X2,Y2,L,C,g1=,g2=,g3,g4;
scanf("%d %d %d %d %d %d",&X1,&Y1,&X2,&Y2,&L,&C);
while(--X1)g1=a[g1].D;while(--X2)g2=a[g2].D;
while(--Y1)g1=a[g1].R;while(--Y2)g2=a[g2].R;
g3=g1;g4=g2;
for(rt i=;i<=L;i++)g1=a[g1].D,g2=a[g2].D,swap(a[g1].R,a[g2].R);
for(rt i=;i<=C;i++)g1=a[g1].R,g2=a[g2].R,swap(a[g1].D,a[g2].D);
for(rt i=;i<=C;i++)g3=a[g3].R,g4=a[g4].R,swap(a[g3].D,a[g4].D);
for(rt i=;i<=L;i++)g3=a[g3].D,g4=a[g4].D,swap(a[g3].R,a[g4].R);
}
int pla=a[a[].D].R;
for(rt i=;i<n;i++,pla=a[pla].D){
for(rt j=,d=pla;j<m;j++,d=a[d].R)printf("%d ",a[d].v);
putchar('\n');
}
return ;
}
codeforces706E的更多相关文章
- 【CodeForces706E】Working routine(二维链表)
BUPT2017 wintertraining(15) #6B 题意 q次操作,每次把两个给定子矩阵交换,求最后的矩阵.(2 ≤ n, m ≤ 1000, 1 ≤ q ≤ 10 000) 题解 用R[ ...
随机推荐
- [luogu3709][大爷的字符串题]
题目链接 题意 一天做到两道这种题目描述如此神仙的题也是够了.真锻炼语文能力. 题目的意思其实就是,给你一个序列,然后每次询问一个区间.使得尽量按照严格上升的顺序从这个区间内取数.如果当前取得数字小于 ...
- Django(十八)Model操作补充
参考博客:http://www.cnblogs.com/wupeiqi/articles/6216618.html 1. 创建类 class UserInfo(model.Model): age = ...
- 都是分号惹的祸 ORA-00911
使用JMeter连接oracle数据库,访问JDBC 请求,执行结果提示:ORA-00911: ??Ч??? 意思为无效的字符错误 说明了在执行的的SQL语句中出现了无效字符,所以在AQL语句无法通过 ...
- eclipse安装activiti 工作流插件
记录一下下eclipse集成activiti插件的过程. eclipse的版本信息为:Version: Mars.1 Release 1 (4.5.1) 下面就开始介绍下如何安装activiti插件. ...
- fcntl F_SETFL
F_SETFL file set flag F_SETFL命令允许更改的标志有O_APPEND,O_NONBLOCK,O_NOATIME,O_DIRECT,O_ASYNC 这个操作修改文件状态标记适用 ...
- IDEA和WebStorm破解教程--激活n年(随时更新)
首先,打开蓝雨的官网--->http://idea.lanyus.com/,找到这个jar包 之后,去官网下载IDEA--->https://www.jetbrains.com/idea ...
- JS判断一个数是否为质数
function isPrime(number) { if (typeof number !== 'number' || number<2) { // 不是数字或者数字小于2 return fa ...
- pageObject+selenium
新发现的设计模式,很好用. 参考:https://www.cnblogs.com/xiaofeifei-wang/p/6733753.html
- C/S,B/S的应用的区别
C/S和B/S都是软件架构方式: C/S(Client/Server) :客户端/服务器结构,其中客户端和服务器端都是独立的计算机,客户端是面向用户的应用程序或者是接口,服务器端通常采用高性能的PC. ...
- shell脚本[] [[]] -n -z 的含义解析
1.在中括号中,判断变量的值, 加不加双引号的问题?-z 判断 变量的值,是否为空: zero = 0 - 变量的值,为空,返回0,为true- 变量的值,非空,返回1,为false-n 判断变量的值 ...