题意各大oj上都有啦..想必来搜题解的都看过题面了...Qw

Solution1:

  首先观察n=1的情况,显然就是中间删掉一个数后面加上一个数,并查询那个删掉的数(以后把这样一个过程称为一个操作啦((:)..

    就是你用什么都可以写..

  然后发现,完整的数据范围就是n+1个n=1的子问题

    就是前n行每行前m-1个数的n个子问题和最后一列的子问题..(有点乱乱啊..语文差..

  然而开n+1棵什么什么树肯定MLE.....下面以线段树为例

    :注意到一次操作,最多更改2log(n)个点,于是就可以愉快动态开点啦(^:

(稍稍借鉴了一下jxc的写法,,好短好妙妙啊

#include<bits/stdc++.h>
using namespace std; const int M = ; struct Node{
Node *lc, *rc;
int l, r, val;
Node(int l = , int r = M << ) {
this->lc = this->rc = NULL;
this->l = l;
this->r = r;
this->val = r - l + ;
}
}; struct SegTree{
Node *rt;
vector<long long> add;
SegTree(void) {
rt = new Node();
add.clear();
}
int Del(Node *p, int x) {
p->val--;
if(p->l == p->r) return p->l;
int mid = (p->l + p->r) >> ;
int lcv = p->lc ? p->lc->val : mid - p->l + ;
if(lcv >= x) {
if(!p->lc) p->lc = new Node(p->l, mid);
return Del(p->lc, x);
} else {
if(!p->rc) p->rc = new Node(mid + , p->r);
return Del(p->rc, x - lcv);
}
}
}line[M + ], row; int n, m, q, x, y;
long long now; int main(void) {
scanf("%d%d%d", &n, &m, &q);
while(q--) {
scanf("%d%d", &x, &y);
int id = row.Del(row.rt, x);
if(id <= n) now = 1LL * id * m;
else now = row.add[id - n - ];
if(y != m) {
line[x].add.push_back(now);
int id = line[x].Del(line[x].rt, y);
if(id < m) now = 1LL * (x - ) * m + id;
else now = line[x].add[id - m];
}
row.add.push_back(now);
printf("%lld\n", now);
}
return ;
}

Solution2:

  注意到BIT不能动态开点(至少我不会啊ov

    于是考虑离线,稍微思考一下,,,,于是发现每一行的查询是独立的,也就是说可以离线之后只开一个BIT

      然后把每一行处理完之后再扔回去就可以保证所有行的查询操作是log的

  这样就预处理完啦

  剩下的就跟之前的一样做就行了(包括那一列的(因为那一列的操作每次都有啊..

#include<bits/stdc++.h>
using namespace std; const int M = ; int val[M << ];
vector<pair<int, int> > query[M]; inline void Add(int x, int y) {
for(; x <= M << ; x += -x & x) val[x] += y;
} inline int Qry(int x) {
int res = ;
for(int i = ; i >= ; i--)
if(( << i) + res <= (M << )) {
if(val[res + ( << i)] < x) {
res += << i;
x -= val[res];
}
}
return res + ;
} void Get_num(int *a, int x) {
for(int i = ; i < query[x].size(); i++) {
pair<int, int> o = query[x][i];
a[o.second] = Qry(o.first);
Add(a[o.second], -);
}
for(int i = ; i < query[x].size(); i++) {
pair<int, int> o = query[x][i];
Add(a[o.second], );
}
} long long now;
vector<long long> last[M];
int n, m, q, x, y, qx[M], qy[M], row[M]; int Read(void) {
int x = ; char ch = getchar();
while(ch < '' || ch > '') ch = getchar();
while(ch <= '' && ch >= '') x = x * + ch - '', ch = getchar();
return x;
} int main(void) {
scanf("%d%d%d", &n, &m, &q);
for(int i = ; i <= q; i++) {
x = Read(); y = Read();
if(y != m) query[x].push_back(make_pair(y, i));
qx[i] = x, qy[i] = y;
} for(int i = ; i <= M << ; i++)
Add(i, );
for(int i = ; i <= n; i++)
Get_num(row, i); for(int i = ; i <= q; i++) {
int id = Qry(qx[i]);
Add(id, -);
if(id <= n) now = 1LL * id * m;
else now = last[][id - n - ];
if(qy[i] < m) {
last[qx[i]].push_back(now);
int id = row[i];
if(id < m) now = 1LL * (qx[i] - ) * m + id;
else now = last[qx[i]][id - m];
}
last[].push_back(now);
printf("%lld\n", now);
}
return ;
}

Solution3:

  据说可以trie做.....不会...

noip2017D2T3的几种写法...(BIT/线段树/平衡树)的更多相关文章

  1. 洛谷 P3919 【模板】可持久化数组(可持久化线段树/平衡树)-可持久化线段树(单点更新,单点查询)

    P3919 [模板]可持久化数组(可持久化线段树/平衡树) 题目背景 UPDATE : 最后一个点时间空间已经放大 标题即题意 有了可持久化数组,便可以实现很多衍生的可持久化功能(例如:可持久化并查集 ...

  2. 洛谷——P3919 【模板】可持久化数组(可持久化线段树/平衡树)

    P3919 [模板]可持久化数组(可持久化线段树/平衡树) 题目背景 UPDATE : 最后一个点时间空间已经放大 标题即题意 有了可持久化数组,便可以实现很多衍生的可持久化功能(例如:可持久化并查集 ...

  3. Luogu P3919【模板】可持久化数组(可持久化线段树/平衡树)

    题面:[模板]可持久化数组(可持久化线段树/平衡树) 不知道说啥,总之我挺喜欢自己打的板子的! #include<cstdio> #include<cstring> #incl ...

  4. luogu P3919 [模板]可持久化数组(可持久化线段树/平衡树)(主席树)

    luogu P3919 [模板]可持久化数组(可持久化线段树/平衡树) 题目 #include<iostream> #include<cstdlib> #include< ...

  5. cf1132G 线段树解分区间LIS(一种全新的线段树解LIS思路)+单调栈

    /* 给定n个数的数列,要求枚举长为k的区间,求出每个区间的最长上升子序列长度 首先考虑给定n个数的数列的LIS求法:从左往右枚举第i点作为最大点的贡献, 那么往左找到第一个比a[i]大的数,设这个数 ...

  6. BZOJ 1146: [CTSC2008]网络管理Network 树链剖分+线段树+平衡树

    1146: [CTSC2008]网络管理Network Time Limit: 50 Sec  Memory Limit: 162 MBSubmit: 870  Solved: 299[Submit] ...

  7. Bzoj 1901: Zju2112 Dynamic Rankings 树套树,线段树,平衡树,Treap

    1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 6471  Solved: 2697[Su ...

  8. CF 19D Points 【线段树+平衡树】

    在平面上进行三种操作: 1.add x y:在平面上添加一个点(x,y) 2.remove x y:将平面上的点(x,y)删除 3.find x y:在平面上寻找一个点,使这个点的横坐标大于x,纵坐标 ...

  9. P3919 【模板】可持久化数组(可持久化线段树/平衡树)

    题目描述 如题,你需要维护这样的一个长度为 N  的数组,支持如下几种操作 在某个历史版本上修改某一个位置上的值 访问某个历史版本上的某一位置的值 此外,每进行一次操作(对于操作2,即为生成一个完全一 ...

随机推荐

  1. HDU 5037 Frog(2014年北京网络赛 F 贪心)

    开始就觉得有思路,结果越敲越麻烦...  题意很简单,就是说一个青蛙从0点跳到m点,最多可以跳l的长度,原有石头n个(都仅表示一个点).但是可能跳不过去,所以你是上帝,可以随便在哪儿添加石头,你的策略 ...

  2. Gerrit使用感受

    CodeReivew好工具,可以随业务需求灵活配置权限等.

  3. DanceLink

    DanceLink是一个可以解决精确覆盖和重复覆盖的搜索算法 重复覆盖就是在精确覆盖的remove等处做改变 都是十字循环链表 精确覆盖 给出一个01矩阵 要求选择几行 使每一列都有且仅有一个1 在求 ...

  4. BZOJ4199/UOJ131 [Noi2015]品酒大会

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...

  5. hdu 5884 Sort 队列+多叉哈夫曼树

    Sort Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Des ...

  6. ANT+JMETER集成3 (添加邮件附件)

    在build.xml文件<email>中加入下面几行代码 <fileset dir="C:\apache-jmeter-3.0\html/"> <in ...

  7. localstorage存储对象

    之前在客户端存储数据一直用的是cookie,由于有大小等限制,随着html5时代的到来,现在大多数用的是localstorage存储数据: 例如: localStorage.setItem(" ...

  8. phpexcel如何读取excel的数据和如何导出数据到excel

    phpexcel如何读取excel的数据和如何导出数据到excel 一.总结 一句话总结:去官网看参考手册和api,或者找中文的博客或者参考手册 1.phpexcel插件如何下载? 其实这些插件不仅可 ...

  9. java: i18n语言

    <%@ page language="java" contentType="text/html; charset=utf8"%> <%@ pa ...

  10. java:file文件类

    public class FileDemo { public static File file; public static void main(String args[]) { String s = ...