4.2 省选模拟赛 旅行路线 广义SAM

\(n\leq 100000\)
题目上求出 多少条本质不同的路线。
首先定义了 相似的城市为度数相同的城市。
还定义了两条路线相同当且仅当长度相同 且对应位置的城市都是相似的。
考虑这张图的形态 n-1条边 且每个点都能到1号点。
不可能出现环 因为 考虑如果出现环必然 x个点 x条边 根据鸽巢原理 一个点被孤立了 所以这是一棵内向树。
暴力显然是把所有长度相同的路线给拿出来然后去重比对。
如何去重 我们考虑把度数相同的点就定义为其度数大小 然后很容易利用hash或者暴力进行比对。
进一步的 发现这类似于字符串。
可以发现 整棵树是一个字典树。问题是 求出本质不同的 子串个数
建立广义SAM.没了。
考虑 字符集1e5 开map 没了...
题解中给了另外一种做法 考虑利用树上SA来求。
发现树上后缀排列不易。最后统计答案也是两个相邻排名的串统计的。
考虑枚举两个相邻排名的串 然后统计一下LCP即可。
LCP可以hash+倍增做 题解中是倍增做了一发SA我不太明白 它是咋做的。
const int MAXN=200010;
int n,cnt=1,len1;ll ans;
int a[MAXN],len[MAXN],f[MAXN];
int lin[MAXN],ver[MAXN],nex[MAXN];
map<int,int>t[MAXN];
inline void add(int x,int y)
{
ver[++len1]=y;
nex[len1]=lin[x];
lin[x]=len1;
++a[x];++a[y];
}
inline int insert(int x,int last)
{
int p=last;
if(t[p].find(x)!=t[p].end())
{
int q=t[p][x];
if(len[q]==len[p]+1)return q;
int nq=++cnt;
t[nq]=t[q];f[nq]=f[q];
len[nq]=len[p]+1;
f[q]=nq;
while(p&&t[p][x]==q)
{
t[p][x]=nq;
p=f[p];
}
return nq;
}
int np=last=++cnt;
len[np]=len[p]+1;
while(p&&t[p][x]==0)
{
t[p][x]=np;
p=f[p];
}
if(!p)f[np]=1;
else
{
int q=t[p][x];
if(len[q]==len[p]+1)f[np]=q;
else
{
int nq=++cnt;
t[nq]=t[q];f[nq]=f[q];
len[nq]=len[p]+1;
f[np]=f[q]=nq;
while(p&&t[p][x]==q)
{
t[p][x]=nq;
p=f[p];
}
}
}
ans+=len[np]-len[f[np]];
return last;
}
inline void dfs(int x,int v)
{
v=insert(a[x],v);
go(x)dfs(tn,v);
}
int main()
{
freopen("route.in","r",stdin);
freopen("route.out","w",stdout);
get(n);
rep(1,n-1,i)
{
int get(x);int get(y);
add(y,x);
}
dfs(1,1);putl(ans);return 0;
}
4.2 省选模拟赛 旅行路线 广义SAM的更多相关文章
- 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解
今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...
- @省选模拟赛03/16 - T3@ 超级树
目录 @description@ @solution@ @accepted code@ @details@ @description@ 一棵 k-超级树(k-SuperTree) 可按如下方法得到:取 ...
- 3.28 省选模拟赛 染色 LCT+线段树
发现和SDOI2017树点涂色差不多 但是当时这道题模拟赛的时候不会写 赛后也没及时订正 所以这场模拟赛的这道题虽然秒想到了LCT和线段树但是最终还是只是打了暴力. 痛定思痛 还是要把这道题给补了. ...
- 省选模拟赛第四轮 B——O(n^4)->O(n^3)->O(n^2)
一 稍微转化一下,就是找所有和原树差距不超过k的不同构树的个数 一个挺trick的想法是: 由于矩阵树定理的行列式的值是把邻接矩阵数值看做边权的图的所有生成树的边权乘积之和 那么如果把不存在于原树中的 ...
- NOI2019省选模拟赛 第五场
爆炸了QAQ 传送门 \(A\) \(Mas\)的童年 这题我怎么感觉好像做过--我记得那个时候还因为没有取\(min\)结果\(100\to 0\)-- 因为是个异或我们肯定得按位考虑贡献了 把\( ...
- NOI2019省选模拟赛 第六场
传送门 又炸了-- \(A\) 唐时月夜 不知道改了什么东西之后就\(A\)掉了\(.jpg\) 首先,题目保证"如果一片子水域曾经被操作过,那么在之后的施法中,这片子水域也一定会被操作&q ...
- 省选模拟赛 arg
1 arg (arg.cpp/in/out, 1s, 512MB)1.1 Description给出一个长度为 m 的序列 A, 请你求出有多少种 1...n 的排列, 满足 A 是它的一个 LIS. ...
- 5.10 省选模拟赛 拍卖 博弈 dp
LINK:拍卖 比赛的时候 前面时间浪费的有点多 写这道题的时候 没剩多少时间了. 随便设了一个状态 就开始做了. 果然需要认真的思考.其实 从我的状态的状态转移中可以看出所有的结论. 这里 就不再赘 ...
- 5.5 省选模拟赛 B Permutation 构造 贪心
LINK:Permutation 对于这种构造神题 我自然是要补的.为啥就我没想出来哇. 30分还是很好写的 注意8!实际上很小 不需要爆搜 写bfs记录状态即可.至于判断状态是否出现与否 可以开ma ...
随机推荐
- 单调栈之WYT的刷子
好久没更题解了(改题困难的我) 题目描述 WYT有一把巨大的刷子,刷子的宽度为M米,现在WYT要使用这把大刷子去粉刷有N列的栅栏(每列宽度都为1米:每列的高度单位也为米,由输入数据给出). 使用刷子的 ...
- C++的基本输入输出
参考:http://www.runoob.com/cplusplus/cpp-basic-input-output.html
- µDoo持有者将分享我们广告总收入的10%,并以BTC支付!
Jason8th October 2019 在数字化世界中,去中心化将是未来,Howdoo的社交媒体和内容交付理念为在新经济中使用的核心用户提供了公平.透明的奖励回报.随着Howdoo上的内容创作者有 ...
- Mac系统权限打开与关闭
打开系统权限: 关闭mac command+R重启 菜单中找到终端 输入命令:csrutil enable 关闭系统权限: 重复以上1-3步骤,第4步时输入:csrutil disable
- 【XCTF】ics-05
信息: 题目来源:XCTF 4th-CyberEarth 标签:PHP.伪协议 题目描述:其他破坏者会利用工控云管理系统设备维护中心的后门入侵系统 解题过程 题目给了一个工控管理系统,并提示存在后门, ...
- 在flask中使用flask-migrate管理数据库
Flask-Migrate是一个为Flask应用处理SQLAlchemy数据库迁移的扩展,使得可以通过Flask的命令行接口或者Flask-Scripts对数据库进行操作. 安装 pip3 insta ...
- 05 drf源码剖析之认证
05 drf源码剖析之认证 目录 05 drf源码剖析之认证 1. 认证简述 2. 认证的使用 3. 源码剖析 4. 总结 1. 认证简述 当我们通过Web浏览器与API进行交互时,我们可以登录,然后 ...
- 02-URLConf调度器
1.工作原理 django通过urlconf来映射视图函数,只区分路径,不区分http方法 Django确定要使用的根URLconf模块,一般是在settings中的ROOT_URLCONF设置的值. ...
- 使用nvm安装node,运行node报错 node: command not found
1. 使用nvm安装node之后,直接运行node命令会报错 node: command not found 需要使用nvm ls 查询一下当前使用的安装的node版本,然后使用node use 版 ...
- 在ASP.NET中,<%= %>和<%# %>有什么区别
asp.net中<%#%>出现在repeater gridview等控件中.用以绑定控件的datasource asp.net中<%%>的意思是 上运行c#或者vb代码,比如: ...