cf707D. Persistent Bookcase(离线+dfs)
题目链接:http://codeforces.com/problemset/problem/707/D
有一个n*m的书架,有K个操作,求每个操作后一共有多少本书;有4种操作;
1:x y 如果 x y 位置没有书,放一本书在上面;
2:x y如果 x y 位置有书,移走;
3:x,表示把第x行的所有又书的拿走,没书的放上去;
4:k,回到第k个操作后的状态;
离线处理k个操作;当操作不为 4 时,把操作i连在i-1后,=4时把操作 i 连在a[i].x后;
这样建一棵树,然后遍历即可,在回溯的时候注意更改书架的状态即可;
#include<iostream>
#include<algorithm>
#include<string.h>
#include<stdio.h>
#include<math.h>
#include<vector>
using namespace std;
#define N 1005
#define PI 4*atan(1.0)
#define mod 1000000007
#define met(a, b) memset(a, b, sizeof(a))
typedef long long LL; struct node
{
int op, x, y, ans;
}a[N*N];///k个操作; int cnt[N][N];///记录书架的状态;
int n, m, k;
vector<vector<int> > G;///操作形成的图; void dfs(int u)
{
if(a[u].op == )
{
int flag = ;
if(cnt[a[u].x][a[u].y] == )
{
flag = ;
a[u].ans ++;///在已有的基础上加上更改的值;
cnt[a[u].x][a[u].y] = ;///标记状态;
}
for(int i=, len=G[u].size(); i<len; i++)
{
int v = G[u][i];
a[v].ans = a[u].ans;///往下走的时候,v是u的儿子,所以拥有u的ans;
dfs(v);
}
if(flag)///回溯时要重新更改状态;
cnt[a[u].x][a[u].y] = ;
}
else if(a[u].op == )
{
int flag = ;
if(cnt[a[u].x][a[u].y] == )
{
flag = ;
a[u].ans --;
cnt[a[u].x][a[u].y] = ;
}
for(int i=, len=G[u].size(); i<len; i++)
{
int v = G[u][i];
a[v].ans = a[u].ans;
dfs(v);
}
if(flag)
cnt[a[u].x][a[u].y] = ;
}
else if(a[u].op == )
{
int num = ;
for(int i=; i<=m; i++)
{
if(cnt[a[u].x][i] == )
num ++;
cnt[a[u].x][i] ^= ;
}
a[u].ans = a[u].ans - num + (m-num);///更新ans;
for(int i=, len=G[u].size(); i<len; i++)
{
int v = G[u][i];
a[v].ans = a[u].ans;
dfs(v);
}
for(int i=; i<=m; i++)
cnt[a[u].x][i] ^= ;
}
else
{
for(int i=, len=G[u].size(); i<len; i++)
{
int v = G[u][i];
a[v].ans = a[u].ans;
dfs(v);
}
}
} int main()
{
while(scanf("%d %d %d", &n, &m, &k)!=EOF)
{
met(a, );
met(cnt, );
G.clear();
G.resize(k+); for(int i=; i<=k; i++)
{
scanf("%d", &a[i].op);
if(a[i].op <= )
scanf("%d %d", &a[i].x, &a[i].y);
else
scanf("%d", &a[i].x); if(a[i].op <= )
G[i-].push_back(i);
else
G[a[i].x].push_back(i);
} for(int i=, len=G[].size(); i<len; i++)
dfs(G[][i]); for(int i=; i<=k; i++)
printf("%d\n", a[i].ans);
}
return ;
}
cf707D. Persistent Bookcase(离线+dfs)的更多相关文章
- CF707D Persistent Bookcase
CF707D Persistent Bookcase 洛谷评测传送门 题目描述 Recently in school Alina has learned what are the persistent ...
- Codeforces Round #368 (Div. 2) D. Persistent Bookcase 离线 暴力
D. Persistent Bookcase 题目连接: http://www.codeforces.com/contest/707/problem/D Description Recently in ...
- CF707D Persistent Bookcase 可持久化线段树
维护一个二维零一矩阵(n,m<=1000),支持四种操作(不超过10^5次): 将(i,j)置一 将(i,j)置零 将第i行零一反转yu 回到第K次操作前的状态 每次操作后输出全局一共有多少个一 ...
- Persistent Bookcase CodeForces - 707D (dfs 离线处理有根树模型的问题&&Bitset)
Persistent Bookcase CodeForces - 707D time limit per test 2 seconds memory limit per test 512 megaby ...
- CodeForces #368 div2 D Persistent Bookcase DFS
题目链接:D Persistent Bookcase 题意:有一个n*m的书架,开始是空的,现在有k种操作: 1 x y 这个位置如果没书,放书. 2 x y 这个位置如果有书,拿走. 3 x 反转这 ...
- 【Codeforces-707D】Persistent Bookcase DFS + 线段树
D. Persistent Bookcase Recently in school Alina has learned what are the persistent data structures: ...
- codeforces 707D D. Persistent Bookcase(dfs)
题目链接: D. Persistent Bookcase time limit per test 2 seconds memory limit per test 512 megabytes input ...
- Codeforces Round #368 (Div. 2) D. Persistent Bookcase
Persistent Bookcase Problem Description: Recently in school Alina has learned what are the persisten ...
- 离线dfs CF div2 707 D
http://codeforces.com/contest/707/problem/D 先说一下离线和在线:在线的意思就是每一个询问单独处理复杂度O(多少多少),离线是指将所有的可能的询问先一次都处理 ...
随机推荐
- 【BZOJ】1049: [HAOI2006]数字序列(lis+特殊的技巧)
http://www.lydsy.com/JudgeOnline/problem.php?id=1049 题意:给一个长度为n的整数序列.把它变成一个单调严格上升的序列.但是不希望改变过多的数,也不希 ...
- redis API使用说明
List相关: LPOP key : 删除并取得LIST头部一个元素 RPOP key : 删除并取得LIST尾部一个元素 BLPOP key [key ...] timeout : 删除并取得LIS ...
- Qt connect parent widget 连接父控件的信号槽
Qt中的信号槽系统是不同类中间传递数据的神器,如果连接父子空间之间的信号槽很重要,在父类中实例化子类的时候一定要注意将父类连上,不然信号槽无法使用,比如若子类是个对话框Dialog类,一定不要忘了加t ...
- jquery判断是否出现滚动条
$(document).ready(function(){ var winH = $(window).height(); //页面可视区域高度 $(window).scroll(function () ...
- https的了解
经常用支付宝,看到了https就查了一下. HTTPS(Secure Hypertext Transfer Protocol)安全超文本传输协议. 简单讲是HTTP的安全版.即HTTP下加入SSL层, ...
- Webscan360的防御与绕过
这两天给360做了一个webscan360的总结,结果补丁还没有出来,就被人公布到了91org上面,既然公开了,那我就做一个总结 首先我们贴上它最新的防御正则 \<.+javascript:wi ...
- Linux网桥设置
1. sudo apt-get install bridge-utils 2. brctl --help Usage: brctl [commands] commands: ad ...
- maven-surefire-plugin总结
Maven通过Maven Surefire Plugin插件执行单元测试.(通过Maven Failsafe Plugin插件执行集成测试) 在pom.xml中配置JUnit,TestNG测试框架的依 ...
- mongodb 3.2 分片部署步骤
#linux 网络优化1. 文件中/etc/sysctl.conf, 加入net.core.somaxconn = 2048fs.file-max = 2000000fs.nr_open = 2000 ...
- [ZZ] Shadow Map
Shadow Map 如何能够高效的产生更接近真实的阴影一直是视频游戏的一个很有挑战的工作,本文介绍目前所为人熟知的两种阴影技术之一的ShadowMap(阴影图)技术. ShadowMap技术 ...