【UER #1】跳蚤OS(Trie)
跳蚤OS 是跳蚤国自主研发的功能强大的操作系统。
跳蚤OS的文件系统与普通的文件系统类似,是个文件夹套文件夹的结构。文件系统根目录称为“//”。我们可以用文件路径来表明文件所在的位置,比如“/flea/uoj/flea/uoj”表示根目录下的fleaflea文件夹下的uojuoj文件。
跳蚤OS的文件系统中。快捷方式是一种特殊的文件夹,点开该快捷方式相当于打开该快捷方式指向的文件夹。
比如,如果有一个快捷方式 “/etc/abc/etc/abc”,该快捷方式指向 “/flea/def/flea/def”这个文件夹,那么一旦访问“/etc/abc/etc/abc”就相当于访问“/flea/def/flea/def”。
这一天,跳蚤国王正在使用跳蚤OS。初始时文件系统为空,只有根目录。他每次会进行如下操作:
- 首先,随便写出两个文件路径 ss 和 tt。
- 接着,如果位置 tt 处不存在文件,则在该处创建一个空文件夹。
- 最后,跳蚤国王保证 ss 这个位置没有文件,于是在 ss 处创建一个快捷方式指向 tt。如果 tt 是个快捷方式,那么 ss 将指向 tt 所指向的文件夹。
上文所说的“创建”在父级目录不存在的时候要一并创建其父级目录。比如,假设文件系统里只有 “/v/v” 这个文件夹,那么现在我创建 “/v/flea/king/qaq/v/flea/king/qaq” 就会在文件系统中新增三个文件夹:“/v/flea/v/flea”, “/v/flea/king/v/flea/king”, “/v/flea/king/qaq/v/flea/king/qaq”。
跳蚤国王进行了 nn 次这样的操作后,开始不断问他的助手伏特:现在我如果在 pp 这个路径处创建一个文件夹(如果已存在则不创建),那么这个文件夹的真实路径是什么?
于是伏特只好向你求助了,请你帮一帮他吧!请参照样例来更清晰地理解题意。
输入格式
第一行两个正整数n,mn,m,表示跳蚤国王进行了nn个操作,提了mm个问题。
接下来nn行每行两个用空格隔开的字符串s,ts,t,表示跳蚤国王的一次操作。
接下来 mm 行每行一个字符串 pp 表示跳蚤国王的一个询问。
保证所有的 s,t,ps,t,p 都是合法的文件路径。即,文件夹名一定是由小写英文字母组成的非空字符串,路径名一定形如“/xxx/xxx/xxx/.../xxx/xxx/xxx/xxx/.../xxx”这样子。保证当路径不为根目录“//”时,路径不以“//”结尾。
输出格式
对于跳蚤国王的每个询问输出真实路径。
样例一
input
6 5
/root /
/duliu /picks
/vfk /vfleaking
/orz/orz/orz /duliu
/otl /duliu/duliu
/vfk/sb /vfleaking
/vfk/sb/nothing/nothing
/orz
/orz/orz/orz
/qaq
/otl
output
/vfleaking/nothing/nothing
/orz
/picks
/qaq
/picks/duliu
explanation
创建的快捷方式分别为:
- /root→//root→/
- /duliu→/picks/duliu→/picks
- /vfk→/vfleaking/vfk→/vfleaking
- /orz/orz/orz→/picks/orz/orz/orz→/picks
- /otl→/picks/duliu/otl→/picks/duliu
- /vfleaking/sb→/vfleaking/vfleaking/sb→/vfleaking
样例二
input
2 3
/ba/la /
/w/o/w /w
/ba/la/ba/la/ba/la/ba/la/ba/la/ba/la/ba/la
/ba/la/ba/la/ba/la/ba/la/ba/la/ba/la/ba/la/ba
/w/o/w/o/w/o/w/o
output
/
/ba
/w/o
样例三
见样例数据下载
限制与约定
| 测试点编号 | nn | mm | 其他 |
|---|---|---|---|
| 1 | ≤200≤200 | ≤10≤10 | 保证单个字符串长度不会超过 4040 |
| 2 | |||
| 3 | |||
| 4 | ≤20000≤20000 | 保证每个输入的路径字符串中仅包含一个“//”且位于字符串开头。 保证单个字符串长度不超过1515。 |
|
| 5 | |||
| 6 | |||
| 7 | ≤20000≤20000 | ||
| 8 | |||
| 9 | |||
| 10 |
对于所有数据,输入中路径字符串总长度不会超过 5×1055×105。
时间限制:1s1s
空间限制:256MB256MB
为了防止有些同学看晕了,我还是再罗嗦几句。下面的路径名都是非法的:
- /orz//orz/
- /orz//otl/orz//otl
- /233/233 (注意,只能含有小写英文字母)
下面的路径名都是合法的:
- //
- /orz/otl/oorrzz/oottll/orz/otl/oorrzz/oottll
- /a
【思路】
Trie+链接
给每个节点加个go指针,使之作为快捷方式链接真实路径字符串在 Trie 中对应的结点。
于是我们可以读入字符串,然后顺着Trie树走。当下一个字符是 “/” 或者已到达字符串结尾时,尝试从 go 指针跳转
【代码】
#include<cmath>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define FOR(a,b,c) for(int a=(b);a<=(c);a++)
using namespace std; const int N = *1e5+; int n,m;
char s[N],q[N]; struct Trie {
int sz; char b[N];
int ch[N][],go[N],fa[N];
Trie() { sz=; }
int insert() {
int u=;
scanf("%s",s);
int len=strlen(s);
if(s[len-]!='/') s[len++]='/';
for(int i=;i<len;i++) {
int c=s[i]-'a';
if(s[i]=='/') c=;
if(!ch[u][c]) {
ch[u][c]=++sz;
fa[sz]=u;
b[sz]=s[i];
}
u=ch[u][c];
if(s[i]=='/') while(go[u]) u=go[u];
}
return u;
}
}T; int main() {
scanf("%d%d",&n,&m);
for(int i=;i<n;i++) {
int x=T.insert(),y=T.insert();
T.go[x]=y;
}
for(int i=;i<m;i++) {
int x=T.insert();
int top=;
for(int i=x;i!=;i=T.fa[i])
q[++top]=T.b[i];
if(top==) puts("/");
else {
while(top>) printf("%c",q[top--]);
puts("");
}
}
return ;
}
【UER #1】跳蚤OS(Trie)的更多相关文章
- 【UER #1】[UOJ#12]猜数 [UOJ#13]跳蚤OS [UOJ#14]DZY Loves Graph
[UOJ#12][UER #1]猜数 试题描述 这一天,小Y.小D.小C正在愉快地玩耍. 小Y是个数学家,他一拍脑袋冒出了一个神奇的完全平方数 n. 小D是个机灵鬼,很快从小Y嘴里套出了 n的值.然后 ...
- 【UOJ #13】【UER #1】跳蚤OS
http://uoj.ac/problem/13 建立trie树,然后建立go指针, 和AC自动机里的fail指针差不多, 走到一个快捷方式就从go指针走. 注意在trie树上要保留字符'/',不能用 ...
- 【UOJ Easy Round #1】
数论/Trie/并查集 猜数 这题我是这样分析的…… $a*b=g*l=n=k^2 \ and \ (g|a,g|b) \Rightarrow (g*a')*(g*b' )=g*l=k^2 \\ \R ...
- 查找(二)简单清晰的B树、Trie树具体解释
查找(二) 散列表 散列表是普通数组概念的推广.因为对普通数组能够直接寻址,使得能在O(1)时间内訪问数组中的任何位置.在散列表中,不是直接把keyword作为数组的下标,而是依据keyword计算出 ...
- B树、Trie树详解
查找(二) 散列表 散列表是普通数组概念的推广.由于对普通数组可以直接寻址,使得能在O(1)时间内访问数组中的任意位置.在散列表中,不是直接把关键字作为数组的下标,而是根据关键字计算出相应的下标. 使 ...
- OS X 与传统Unix的一点区别
在传统的Unix系统或者Linux系统中,你是很难在根目录下找到大写开头的文件夹的, 但是看一下OS X: ls / Applications Users etc private var Develo ...
- NodeJs之OS
OS Node.js提供了一些基本的底层操作系统的模块OS. API var os = require('os'); console.log('[arch] 操作系统CPU架构'+os.arch()) ...
- Node.js:OS模块
os模块,可以用来获取操作系统相关的信息和机器物理信息,例如操作系统平台,内核,cpu架构,内存,cpu,网卡等信息. 使用如下所示: const os = require('os'); var de ...
- Xamarin+Prism开发详解四:简单Mac OS 虚拟机安装方法与Visual Studio for Mac 初体验
Mac OS 虚拟机安装方法 最近把自己的电脑升级了一下SSD固态硬盘,总算是有容量安装Mac 虚拟机了!经过心碎的安装探索,尝试了国内外的各种安装方法,最后在youtube上找到了一个好方法. 简单 ...
随机推荐
- MVC-简单验证码制作
1.制作验证码: using System; using System.Collections.Generic; using System.Drawing; using System.Drawing. ...
- ZOJ 3471 压缩状态DP
这个问题要看状态怎么想,第一种直接的想法是1代表未合并,状态就从1111111 转移到 带有1个0,然后带有两个0, 但是这样子编程非常不直观.换一种思路,0代表未合并,但是我可以先合并前几个,就是说 ...
- ASP.NET MVC 3 Razor Views in SharePoint
http://tqcblog.com/2011/01/22/asp-net-mvc-3-razor-views-in-sharepoint/ ASP.NET MVC 3 has just been r ...
- 蓝桥杯——FJ字符串
FJ在沙盘上写了这样一些字符串: A1 = "A"1 A2 = "ABA"3 A3 = "ABACABA"7 A4 = "ABAC ...
- DOS下文件操作命令
文件名是由文件路径和文件名称合起来的,如C:\DOS\COMMAND.COM. DIR 显示文件和文件夹(目录). 用法:DIR [文件名] [选项] 它有很多选项,如/A表示显示所有文件(即包括带隐 ...
- w3c subscribe
http://www.w3.org/html/ig/zh/ http://blog.csdn.net/spring21st/article/details/6126537 http://www.w3c ...
- Datadog Agent是啥?它消耗什么资源?
在资本市场不那么喜人的 2015 年融资 9450 万美元的 Datadog,在运维圈刮起了一阵小旋风.作为国外很值得学习的一款平台监控产品,公司人数不足 100 的 Datadog 为什么吸引了投资 ...
- MySQL函数讲解(MySQL函数大全)
讲mysql函数之前先给大家展示一下利用mysql函数的一个例子: SELECT i.item_id, i.item_name, i.cid, i.last_update_time, u.url, u ...
- KMP的next[]数组
KMP是众多字符串问题的基础 理解next数组尤为重要 next又称前缀数组 是 它所处位置的前一个位置的元素 与 该链 链首开始 几个元素相匹配(即相同) 举个实例来说明: next对应的是该位置的 ...
- lib-flexible 结合 WKWebView 的样式错乱解决方法
技术栈 lib-flexible 是淘宝的可伸缩方案 WKWebView 是ios8以上支持的网页控件 问题场景 最新公司一个项目使用 lib-flexible 来做移动端的伸缩解决方案,页面在saf ...