【BZOJ 4569】【SCOI 2016】萌萌哒

时间:2022-12-22 13:33:59

http://www.lydsy.com/JudgeOnline/problem.php?id=4569

用ST表表示所有区间,根据ST表中表示的区间长度种一棵nlogn的树,类似线段树,每个节点的左孩子和右孩子表示的区间拼接起来的总区间即为这个节点表示的区间。树上同一层节点表示的区间长度相同,同一层节点就可以用并查集来维护。

这样对于m个限制,用ST表把每个限制中的区间拆成前一块和后一块两块,限制中要求相同的两个区间的前一块和后一块分别用并查集合并,可以满足这两个区间完全相同。

最后从树的顶部(树根可能有很多)逐层下推就可以啦(把这一层两个区间相同的信息下推到这两个区间在下一层中的前一块相同并且后一块相同)~~~推到最底层统计有多少个不相同的数字,(个数-1)×10×9即为答案。

时间复杂度$O(n\log na(n)+ma(n))$

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 100003;
int in() {
int k = 0, fh = 1; char c = getchar();
for(; c < '0' || c > '9'; c = getchar())
if (c == '-') fh = -1;
for(; c >= '0' && c <= '9'; c = getchar())
k = (k << 3) + (k << 1) + c - '0';
return k * fh;
} int n, m, f[N][18], cnt, lson[N * 18], rson[N * 18], fa[N * 18], Log_2[N]; void init() {
cnt = 0;
for(int i = 1; i <= n; ++i) {
if ((1 << (cnt + 1)) <= i) ++cnt;
Log_2[i] = cnt;
}
cnt = 0;
for(int j = 0; (1 << j) <= n; ++j)
for(int i = 1; i + (1 << j) - 1 <= n; ++i) {
f[i][j] = ++cnt;
lson[cnt] = f[i][j - 1];
rson[cnt] = f[i + (1 << (j - 1))][j - 1];
}
for(int i = 1; i <= cnt; ++i) fa[i] = i;
} int find(int a) {
if (fa[a] == a) return a;
fa[a] = find(fa[a]); return fa[a];
}
void merge(int a, int b) {
a = find(a); b = find(b);
if (a != b) fa[a] = b;
} int main() {
n = in(); m = in();
init();
int len, x1, y1, x2, y2;
while (m--) {
x1 = in(); y1 = in(); x2 = in(); y2 = in();
len = Log_2[y1 - x1 + 1];
merge(f[x1][len], f[x2][len]);
merge(f[y1 - (1 << len) + 1][len], f[y2 - (1 << len) + 1][len]);
} int t;
for(int i = cnt; i > n; --i)
if ((t = find(i)) != i) {
merge(lson[i], lson[t]);
merge(rson[i], rson[t]);
} t = 0;
for(int i = 1; i <= n; ++i)
if (find(i) == i) ++t;
int ret = 9;
while (--t) ret = (int) (1ll * ret * 10 % 1000000007);
printf("%d\n", ret);
return 0;
}

对于区间相同之类的限制,即区间操作,线段树往往是十分强大的。但也有线段树解决不了的题,就像这道题,因为线段树表示区间的logn个节点是"不规则的",随区间位置的改变而变化,这样对于两个不同位置相同长度的区间就很难用并查集来维护了。没有区间修改操作时,ST表表现的十分优越,不仅可以$O(1)$回答可合并信息,而且可以快速的且有规律的将区间"剖分",结合其他数据结构很方便地维护两个长度相同的区间之间的关系。

【BZOJ 4569】【SCOI 2016】萌萌哒的更多相关文章

  1. SCOI 2016 萌萌哒

    SCOI 2016 萌萌哒 solution 有点线段树的味道,但是并不是用线段树来做,而是用到另外一个区间修改和查询的利器--ST表 我们可以将一个点拆成\(logN\)个点,分别代表从点\(i\) ...

  2. &lbrack;Luogu P3295&rsqb;&lbrack;SCOI 2016&rsqb;萌萌哒

    先说下暴力做法,如果[l1,r1]和[l2,r2]子串相等等价于两个区间内每个数对应相等.那么可以用并查集暴力维护,把对应相等的数的位置维护到同一个集合里去,最后答案其实就是把每个集合可以放的数个数乘 ...

  3. bzoj 4568 &lbrack;SCOI 2016&rsqb; 幸运数字

    题目大意 给定一棵\(n\)个点的树,每个点有权值 \(q\)次询问树上路径中 每个点权值可选可不选的最大异或和 \(n\le 2*10^4,q\le 2*10^5,val[i]\le 2^{60}\ ...

  4. BZOJ 4569 &lbrack;Scoi2016&rsqb;萌萌哒 &vert; ST表 并查集

    传送门 BZOJ 4569 题解 ST表和并查集是我认为最优雅(其实是最好写--)的两个数据结构. 然鹅!他俩加一起的这道题,我却--没有做出来-- 咳咳. 正解是这样的: 类似ST表有\(\log ...

  5. &lbrack;LOJ 2083&rsqb;&lbrack;UOJ 219&rsqb;&lbrack;BZOJ 4650&rsqb;&lbrack;NOI 2016&rsqb;优秀的拆分

    [LOJ 2083][UOJ 219][BZOJ 4650][NOI 2016]优秀的拆分 题意 给定一个字符串 \(S\), 求有多少种将 \(S\) 的子串拆分为形如 AABB 的拆分方案 \(| ...

  6. &lbrack;BZOJ 4455&rsqb; &lbrack;ZJOI 2016&rsqb; 小星星 &lpar;树形dp&plus;容斥原理&plus;状态压缩&rpar;

    [BZOJ 4455] [ZJOI 2016] 小星星 (树形dp+容斥原理+状态压缩) 题面 给出一棵树和一个图,点数均为n,问有多少种方法把树的节点标号,使得对于树上的任意两个节点u,v,若树上u ...

  7. BZOJ 4569 萌萌哒

    题目传送门 4569: [Scoi2016]萌萌哒 Time Limit: 10 Sec Memory Limit: 256 MB Submit: 483 Solved: 221 [Submit][S ...

  8. 【BZOJ 4568】【SCOI 2016】幸运数字

    写了一天啊,调了好久,对拍了无数次都拍不出错来(数据生成器太弱了没办法啊). 错误1:把线性基存成结构体,并作为函数计算,最后赋值给调用函数的变量时无疑加大了计算量导致TLE 错误2:像这种函数(A, ...

  9. 【BZOJ 4569】 4569&colon; &lbrack;Scoi2016&rsqb;萌萌哒 (倍增&plus;并查集)

    4569: [Scoi2016]萌萌哒 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 865  Solved: 414 Description 一个长 ...

随机推荐

  1. 用Get-ADComputer取非常用属性的值

    由于GE使用的是Windows2003+Powershell2.0, 所以某些命令无法使用,比如想取lastLogon和lastLogonTimestamp这两个属性,在Powershell3.0下可 ...

  2. gVIM 简洁配置 in Windows

    原文链接:http://www.errdev.com/post/2/ 捣鼓了一段时间的VIM,神器终归是神器,果然编码效率提升了许多,当然还需要很多插件来配合.自己装插件很麻烦,还要有Vundle这个 ...

  3. 图解JS原型链

    一:任何一个对象都有一个prototype的属性,在js中可以把它记为:__proto__ 当初ECMAscript的发明者为了简化这门语言,同时又保持继承的属性,于是就设计了这个链表.. 在数据结构 ...

  4. centos6&period;4 ceph安装部署之ceph object storage

    preface: ceph-deploy does not provide a rapid installation for Ceph Object Storage install Configura ...

  5. UTL&lowbar;FILE 的用法

    UTL_FILE 的用法   UTL_FILE 是用来进行文件IO处理的专用包,使用这外包的注意事项如下: 1. 生成的文件好象只能放置在DATABASE所在的服务器路径中. 2. 生成的文件如何DO ...

  6. JS中将一个值转换为字符串的3种方法

    1.value.toString() 2."" + value 3.String(value) 第一种方法存在的问题是,它不能把null和undefined转换为字符串.还有第二种 ...

  7. Spring MVC 使用介绍(十二)控制器返回结果统一处理

    一.概述 在为前端提供http接口时,通常返回的数据需要统一的json格式,如包含错误码和错误信息等字段. 该功能的实现有四种可能的方式: AOP 利用环绕通知,对包含@RequestMapping注 ...

  8. 20162322 朱娅霖 作业011 Hash

    20162322 2017-2018-1 <程序设计与数据结构>第十一周学习总结 教材学习内容总结 哈希方法 一.定义 哈希:次序--更具体来说是项在集合中的位置--由所保存元素值的某个函 ...

  9. linux每日命令&lpar;32&rpar;:gzip命令

    减少文件大小有两个明显的好处,一是可以减少存储空间,二是通过网络传输文件时,可以减少传输的时间.gzip是在Linux系统中经常使用的一个对文件进行压缩和解压缩的命令,既方便又好用.gzip不仅可以用 ...

  10. (原创)OpenStack服务如何使用Keystone&lpar;一&rpar;---Keystone端的操作

    (一)Keystone端的操作 (二)如何在OpenStack服务上部署Keystone中间件 (三)详细配置keystonemiddleware OpenStack项目如果要使用Keystone作为 ...