题解

题面太长无法阅读系列……

这里说的选择改变指的是在下面区间里碰上了一个更长的可匹配的地址,如果可匹配但是匹配长度没有当前的值大,那么不算改变

我们建一个可持久化的trie,查询的时候先在前\(a - 1\)个里找到最长的可以得到的地址

然后再在区间的trie里找到那条链上,如果碰到一个结束点且比我们初始长度大的路径串,就丢进一个栈里,维护栈的递增

最后栈的长度就是答案

代码

#include <bits/stdc++.h>
#define enter putchar('\n')
#define space putchar(' ')
#define pii pair<int,int>
#define fi first
#define se second
#define MAXN 1000005
#define pb push_back
#define mp make_pair
#define eps 1e-8
//#define ivorysi
using namespace std;
typedef long long int64;
typedef double db;
template<class T>
void read(T &res) {
res = 0;T f = 1;char c = getchar();
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 + c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) out(x / 10);
putchar('0' + x % 10);
}
int M;
char s[35];
struct node {
int son[2],siz,ed;
}tr[MAXN * 32];
int Ncnt,rt[MAXN],cnt;
int sta[MAXN],top;
void Insert(int v,int l) {
rt[++cnt] = ++Ncnt;
int *y = &rt[cnt],x = rt[cnt - 1];
tr[*y] = tr[x];
for(int i = 31 ; i >= 31 - l + 1 ; i--) {
int c = (v >> i) & 1;
y = &tr[*y].son[c];x = tr[x].son[c];
*y = ++Ncnt;
tr[*y] = tr[x];
tr[*y].siz++;
}
if(!tr[*y].ed) tr[*y].ed = cnt;
}
int Get_MaxL(int a,int v) {
int p = rt[a];
int res = 0;
for(int i = 31 ; i >= 0 ; --i) {
int c = (v >> i) & 1;
if(tr[p].son[c]) p = tr[p].son[c];
else break;
if(tr[p].ed) res = max(res,31 - i + 1);
}
return res;
}
int Query(int L,int R,int v,int len) {
top = 0;
--L;
int x = rt[L],y = rt[R];
for(int i = 31 ; i >= 0 ; --i) {
int c = (v >> i) & 1;
if(tr[tr[y].son[c]].siz - tr[tr[x].son[c]].siz) {
y = tr[y].son[c];x = tr[x].son[c];
}
else break;
if(tr[y].ed && 31 - i + 1 > len) {
while(top && sta[top] > tr[y].ed) --top;
sta[++top] = tr[y].ed;
}
}
return top;
}
void Solve() {
read(M);
int a,b;
while(M--) {
scanf("%s",s + 1);
if(s[1] == 'A') {
scanf("%s",s + 1);
int L = strlen(s + 1);
int v = 0,now = 0;
for(int i = 1 ; i <= L ; ++i) {
if(s[i] == '.' || s[i] == '/') {
v = v << 8 | now;
now = 0;
}
else now = now * 10 + s[i] - '0';
}
Insert(v,now);
}
else {
scanf("%s",s + 1);
int L = strlen(s + 1);
int v = 0,now = 0;
for(int i = 1 ; i <= L ; ++i) {
if(s[i] == '.') {
v = v << 8 | now;
now = 0;
}
else now = now * 10 + s[i] - '0';
}
v = v << 8 | now;
read(a);read(b);
L = Get_MaxL(a - 1,v);
out(Query(a,b,v,L));enter;
}
}
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
return 0;
}

【LOJ】#2046. 「CQOI2016」路由表的更多相关文章

  1. loj #2044. 「CQOI2016」手机号码

    #2044. 「CQOI2016」手机号码 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据   题目描述 ...

  2. loj2046 「CQOI2016」路由表

    大傻逼trie树,更傻逼的是我这都没独立想出来,以后要少看题解,多多思考 #include <algorithm> #include <iostream> #include & ...

  3. LoibreOJ 2042. 「CQOI2016」不同的最小割 最小割树 Gomory-Hu tree

    2042. 「CQOI2016」不同的最小割 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据   题目描述 ...

  4. Loj #2192. 「SHOI2014」概率充电器

    Loj #2192. 「SHOI2014」概率充电器 题目描述 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品--概率充电器: 「采用全新纳米级加工技术,实现元件与导线能否通电完 ...

  5. Loj #3096. 「SNOI2019」数论

    Loj #3096. 「SNOI2019」数论 题目描述 给出正整数 \(P, Q, T\),大小为 \(n\) 的整数集 \(A\) 和大小为 \(m\) 的整数集 \(B\),请你求出: \[ \ ...

  6. Loj #3093. 「BJOI2019」光线

    Loj #3093. 「BJOI2019」光线 题目描述 当一束光打到一层玻璃上时,有一定比例的光会穿过这层玻璃,一定比例的光会被反射回去,剩下的光被玻璃吸收. 设对于任意 \(x\),有 \(x\t ...

  7. Loj #3089. 「BJOI2019」奥术神杖

    Loj #3089. 「BJOI2019」奥术神杖 题目描述 Bezorath 大陆抵抗地灾军团入侵的战争进入了僵持的阶段,世世代代生活在 Bezorath 这片大陆的精灵们开始寻找远古时代诸神遗留的 ...

  8. Loj #2542. 「PKUWC2018」随机游走

    Loj #2542. 「PKUWC2018」随机游走 题目描述 给定一棵 \(n\) 个结点的树,你从点 \(x\) 出发,每次等概率随机选择一条与所在点相邻的边走过去. 有 \(Q\) 次询问,每次 ...

  9. Loj #3059. 「HNOI2019」序列

    Loj #3059. 「HNOI2019」序列 给定一个长度为 \(n\) 的序列 \(A_1, \ldots , A_n\),以及 \(m\) 个操作,每个操作将一个 \(A_i\) 修改为 \(k ...

随机推荐

  1. nova-compute源码分析

    源码版本:H版 首先看启动脚本如下: /usr/bin/nova-compute import sys from nova.cmd.compute import main if __name__ == ...

  2. JS中浮点数精度误差解决

    问题出现 0.1 + 0.2 = 0.30000000000000004 问题分析 对于浮点数的四则运算,几乎所有的编程语言都会有类似精度误差的问题,只不过在 C++/C#/Java 这些语言中已经封 ...

  3. [NOI1999] 棋盘分割

    COGS 100. [NOI1999] 棋盘分割 http://www.cogs.pro/cogs/problem/problem.php?pid=100 ★★   输入文件:division.in  ...

  4. TOMCAT添加管理用户认证

    添加配置文件 --原配置文件: # tail -5 /usr/local/tomcat/conf/tomcat-users.xml <user username="tomcat&quo ...

  5. 关于安装在win10上的oracle10g 兼容性问题

    首先在安装过程中会出现一次报错,在安装的时候 安装好了以后,准备敲击命令如果出现闪退,即是兼容性问题,下面继续设置兼容性问题 然后右键----属性----兼容性,勾上以兼容性运行即可

  6. 20155321 2016-2017-2 《Java程序设计》第七周学习总结

    20155321 2016-2017-2 <Java程序设计>第七周学习总结 教材学习内容总结 Date/DateFormat Date是日期类,可以精确到毫秒. 构造方法 Date() ...

  7. ubuntu16.04 源码方法安装tensorflow

    参考博客:http://blog.csdn.net/zhaoyu106/article/details/52793183/,http://blog.csdn.net/u010900574/articl ...

  8. sleep命令

    sleep支持睡眠(分,小时) sleep 1 睡眠1秒 sleep 1s 睡眠1秒 sleep 1m 睡眠1分 sleep 1h 睡眠1小时

  9. Ubuntu server 搭建Git server【转】

    转自:http://www.cnblogs.com/candle806/p/4064610.html Ubuntu server 搭建Git server,git相比svn,最主要就是分布式了,每个客 ...

  10. swagger学习

    https://segmentfault.com/a/1190000010144742 https://segmentfault.com/a/1190000014775124 https://blog ...