Luogu P3294 【[SCOI2016]背单词】
阅读理解题
。。。。。。
$Trie$
后缀问题不好处理,我们把它转化为前缀问题,用字典树解决问题
贪心
容易想到,一个串的后缀要先于它插入
对于一个串和其若干后缀串,容易想到,我们要先插入后缀串
然后递归进入$size$最小的子串
bool cmp(const int &x,const int &y)
{
return size[x]<size[y];
}
void makes(int x)
{
size[x]=;
for(int i=;i<t[x].size();i++)
{
makes(t[x][i]);
size[x]+=size[t[x][i]];
}
sort(t[x].begin(),t[x].end(),cmp);
}
void dfs(int x)
{
id[x]=tot++;
for(int i=;i<t[x].size();i++)
{
ans+=tot-id[x];
dfs(t[x][i]);
}
}
注意
求$size$要重构树,只保留关键点
因为我太蒻了,并不会指针,所以提供一个并查集重构树的方法
在建$Trie$时给所有串的结尾和$Trie$树的根节点标号,表示新树中点的编号
void insert(const string &s,int id)
{
int now=,l=len[id];
for(int i=;i<l;i++)
{
int c=idx(s[i]);
now=tr[now][c]?tr[now][c]:tr[now][c]=++cnt;
}
val[now]=id;
}
然后遍历$Trie$树,如果一个节点的子节点没有被标号,就把它并入当前节点的集合;否则把这个子节点作为当前节点所在集合的根的儿子(就是连一条边)
void make(int x)
{
for(int v,i=;i<;i++)
if(v=tr[x][i])
{
if(!val[v])
f[v]=find(x);
else
t[val[find(x)]].push_back(val[v]);
make(v);
}
}
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#define int long long
using namespace std;
const int maxl=,maxn=1e5+;
int n,tr[maxl][],val[maxl],cnt,len[maxn],size[maxn],tot,f[maxl],id[maxn],ans;
vector<int>t[maxn];
string st[maxn];
inline int find(int x)
{
return x==f[x]?x:f[x]=find(f[x]);
}
inline int idx(char c)
{
return c-'a';
}
void insert(const string &s,int id)
{
int now=,l=len[id];
for(int i=;i<l;i++)
{
int c=idx(s[i]);
now=tr[now][c]?tr[now][c]:tr[now][c]=++cnt;
}
val[now]=id;
}
void make(int x)
{
for(int v,i=;i<;i++)
if(v=tr[x][i])
{
if(!val[v])
f[v]=find(x);
else
t[val[find(x)]].push_back(val[v]);
make(v);
}
}
bool cmp(const int &x,const int &y)
{
return size[x]<size[y];
}
void makes(int x)
{
size[x]=;
for(int i=;i<t[x].size();i++)
{
makes(t[x][i]);
size[x]+=size[t[x][i]];
}
sort(t[x].begin(),t[x].end(),cmp);
}
void dfs(int x)
{
id[x]=tot++;
for(int i=;i<t[x].size();i++)
{
ans+=tot-id[x];
dfs(t[x][i]);
}
}
signed main()
{
scanf("%lld",&n);
for(int i=;i<=n;i++)
{
cin>>st[i];
len[i]=st[i].length();
for(int j=;j<len[i]/;j++)
swap(st[i][j],st[i][len[i]-j-]);
insert(st[i],i);
}
for(int i=;i<=cnt;i++)
f[i]=i;
make(),makes(),dfs();
printf("%lld\n",ans);
return ;
}
Luogu P3294 【[SCOI2016]背单词】的更多相关文章
- [luogu] P3294 [SCOI2016]背单词 (贪心)
题目描述 Lweb 面对如山的英语单词,陷入了深深的沉思,"我怎么样才能快点学完,然后去玩三国杀呢?".这时候睿智的凤老师从远处飘来,他送给了 Lweb 一本计划册和一大缸泡椒,他 ...
- P3294 [SCOI2016]背单词
P3294 [SCOI2016]背单词 Trie+贪心 倒插进树+取出重建+子树处理+贪心遍历 倒插进树:把后缀转化为前缀,所以把字符串倒着插进Trie中 取出重建:重新建立一棵以单词为节点的树,如果 ...
- 洛谷P3294 [SCOI2016]背单词——题解
题目传送 阅读理解题题意解释可以看这位大佬的博客. 发现求后缀与倒序求前缀是等价的,而找前缀自然就想到了trie树.将所有字符串翻转后再建入trie树中,再对每一个字符串翻转后从trie树中找前缀,就 ...
- BZOJ4567[Scoi2016]背单词
4567: [Scoi2016]背单词 Time Limit: 10 Sec Memory Limit: 256 MB Submit: 304 Solved: 114 [Submit][Status] ...
- 4567: [Scoi2016]背单词
4567: [Scoi2016]背单词 https://www.lydsy.com/JudgeOnline/problem.php?id=4567 题意: 题意看了好久,最后在其他人的博客里看懂了的. ...
- 【BZOJ4567】[Scoi2016]背单词 Trie树+贪心
[BZOJ4567][Scoi2016]背单词 Description Lweb 面对如山的英语单词,陷入了深深的沉思,“我怎么样才能快点学完,然后去玩三国杀呢?”.这时候睿智 的凤老师从远处飘来,他 ...
- 【bzoj4567】[Scoi2016]背单词
4567: [Scoi2016]背单词 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1123 Solved: 476[Submit][Status][ ...
- [SCOI2016]背单词 题解
背单词 https://www.luogu.com.cn/problem/P3294 前言: Trie树的省选题(瑟瑟发抖QAQ) 问题汇总:(请忽略) (1)对Trie字典树的运用不熟练 (2)没想 ...
- [SCOI2016]背单词——trie树相关
题目描述 Lweb 面对如山的英语单词,陷入了深深的沉思,”我怎么样才能快点学完,然后去玩三国杀呢?“.这时候睿智的凤老师从远处飘来,他送给了 Lweb 一本计划册和一大缸泡椒,他的计划册是长这样的: ...
随机推荐
- Dom--属性以及创建标签
一.Dom属性 1.1 设置属性(setAttribute) 设置某个标签的属性,setAttribute(key,value) <body> <div> <input ...
- JQ版本对比
JQ不知不觉来到第三版了,那么它们有什么不同呢? 下面先给大家推一个CDN加速的网站,上面有各种JQ的版本:http://www.bootcdn.cn/jquery/ 先来对比一下它们的“体重”,23 ...
- JS 中函数名后面加与不加括号的区别
a.onmouseover = fn1; a.onmouseout = fn2; function fn1(){ div.className = "erweima show"; } ...
- JAVA记录-redis缓存机制介绍(三)
Redis 事务 Redis 事务可以一次执行多个命令, 并且带有以下两个重要的保证: 事务是一个单独的隔离操作:事务中的所有命令都会序列化.按顺序地执行.事务在执行的过程中,不会被其他客户端发送来的 ...
- div显示提示信息【转】
div显示提示信息 <body> <style type="text/css"> a.link{position:relative;} a.link div ...
- Python基础(协程函数、内置函数、递归、模块和包)-day05
写在前面 上课第五天,打卡: 凭着爱,再回首: 一.协程函数(生成器:yield的表达式形式) 1.yield 的语句形式: yield 1 - 这种方式在 Python基础(函数部分)-day04 ...
- 简易selenium自动化测试框架(Python)
最近空闲时间在探索Selenium的自动化测试,简单的写了一个小框架来测试公司的一个web产品.该框架包括以下模块: 1. Test case编写模式(page模式,参考之前的博文http://www ...
- 解决virtualbox与mac文件拖拽问题
apt-get purge virtualbox-guest-x11apt-get autoremove --purgerebootapt-get updateapt-get dist-upgrade ...
- JavaScript之Array/数组小结
MDN-Array的属性/方法:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Arr ...
- np.savetxt()——将array保存到txt文件,并保持原格式
问题:1.如何将array保存到txt文件中?2.如何将存到txt文件中的数据读出为ndarray类型? 需求:科学计算中,往往需要将运算结果(array类型)保存到本地,以便进行后续的数据分析. 解 ...