题目链接: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)的更多相关文章

  1. CF707D Persistent Bookcase

    CF707D Persistent Bookcase 洛谷评测传送门 题目描述 Recently in school Alina has learned what are the persistent ...

  2. Codeforces Round #368 (Div. 2) D. Persistent Bookcase 离线 暴力

    D. Persistent Bookcase 题目连接: http://www.codeforces.com/contest/707/problem/D Description Recently in ...

  3. CF707D Persistent Bookcase 可持久化线段树

    维护一个二维零一矩阵(n,m<=1000),支持四种操作(不超过10^5次): 将(i,j)置一 将(i,j)置零 将第i行零一反转yu 回到第K次操作前的状态 每次操作后输出全局一共有多少个一 ...

  4. Persistent Bookcase CodeForces - 707D (dfs 离线处理有根树模型的问题&&Bitset)

    Persistent Bookcase CodeForces - 707D time limit per test 2 seconds memory limit per test 512 megaby ...

  5. CodeForces #368 div2 D Persistent Bookcase DFS

    题目链接:D Persistent Bookcase 题意:有一个n*m的书架,开始是空的,现在有k种操作: 1 x y 这个位置如果没书,放书. 2 x y 这个位置如果有书,拿走. 3 x 反转这 ...

  6. 【Codeforces-707D】Persistent Bookcase DFS + 线段树

    D. Persistent Bookcase Recently in school Alina has learned what are the persistent data structures: ...

  7. codeforces 707D D. Persistent Bookcase(dfs)

    题目链接: D. Persistent Bookcase time limit per test 2 seconds memory limit per test 512 megabytes input ...

  8. Codeforces Round #368 (Div. 2) D. Persistent Bookcase

    Persistent Bookcase Problem Description: Recently in school Alina has learned what are the persisten ...

  9. 离线dfs CF div2 707 D

    http://codeforces.com/contest/707/problem/D 先说一下离线和在线:在线的意思就是每一个询问单独处理复杂度O(多少多少),离线是指将所有的可能的询问先一次都处理 ...

随机推荐

  1. 关于 List<T>

    System.Object   System.Collections.Generic.List<T>   list<string,string>,这种形式本身就是错误的,你可以 ...

  2. TYVJ 1011 NOIP 2008&&NOIP 2000 传纸条&&方格取数 Label:多线程dp

    做题记录:2016-08-15 15:47:07 背景 NOIP2008复赛提高组第三题 描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行 ...

  3. 【POJ】1228 Grandpa's Estate(凸包)

    http://poj.org/problem?id=1228 随便看看就能发现,凸包上的每条边必须满足,有相邻的边和它斜率相同(即共线或凸包上每个点必须一定在三点共线上) 然后愉快敲完凸包+斜率判定, ...

  4. 关于HTML条件注释你可能不知道的一些事儿

    最近经常看到类似这样的HTML代码片段,很多前端开发人员应该都熟悉: 1 <!--[if lt IE 7]>      <html class="ie6"> ...

  5. 4.用文本编辑器输入课堂上练习的Hello.java,并在JDK环境下编译和运行。请将程序编译、运行的结果截图,填入下框中。

    一开始报错是因为在文本框了的:用的是中文下的,应该用英文下的;

  6. 如何安装ESXi的补丁

    1.进入维护模式 2.通过vSphere Client上传补丁 3.开SSH后使用Putty连接 4.esxcli software vib install -d="/vmfs/volume ...

  7. 《GK101任意波发生器》升级固件发布(版本:1.0.2.build124)

    一.固件说明: 硬件版本:0,logic.3 固件版本:1.0.2.build124 编译日期:2014-08-19 ====================================== 二. ...

  8. svn搭建,很简单

    yum install subversion 2015年1月7日15:23:07 我测试的时间 系统是centos6.5 直接yum,centos是可以直接解决apr apr-util 依赖问题,如果 ...

  9. 使用spring等框架的web程序在Tomcat下的启动顺序及思路理清

    大牛请绕过,此文仅针对自己小白水平,对web程序的启动流程做个清晰的回顾. 一.使用spring等框架的web程序在Tomcat下的启动流程 1)Tomcat是根据web.xml来启动的.首先到web ...

  10. Supesite 参数说明

    supesite有人看到的是强大的功能,我看到的是坑爷的一些用法,第一次看到block,我晕了.对于参数一头雾水,下面收集了一些,备用吧. supesite标签调用参数详解 参数: blocktype ...