P3065 [USACO12DEC]第一!First!
题目描述
Bessie has been playing with strings again. She found that by
changing the order of the alphabet she could make some strings come before all the others lexicographically (dictionary ordering).
For instance Bessie found that for the strings "omm", "moo", "mom", and "ommnom" she could make "mom" appear first using the standard alphabet and that she could make "omm" appear first using the alphabet
"abcdefghijklonmpqrstuvwxyz". However, Bessie couldn't figure out any way to make "moo" or "ommnom" appear first.
Help Bessie by computing which strings in the input could be
lexicographically first by rearranging the order of the alphabet. To compute if string X is lexicographically before string Y find the index of the first character in which they differ, j. If no such index exists then X is lexicographically before Y if X is shorter than Y. Otherwise X is lexicographically before Y if X[j] occurs earlier in the alphabet than Y[j].
Bessie一直在研究字符串。她发现,通过改变字母表的顺序,她可以按改变后的字母表来排列字符串(字典序大小排列)。
例如,Bessie发现,对于字符串串“omm”,“moo”,“mom”和“ommnom”,她可以使用标准字母表使“mom”排在第一个(即字典序最小),她也可以使用字母表“abcdefghijklonmpqrstuvwxyz”使得“omm”排在第一个。然而,Bessie想不出任何方法(改变字母表顺序)使得“moo”或“ommnom”排在第一个。
接下来让我们通过重新排列字母表的顺序来计算输入中有哪些字符串可以排在第一个(即字典序最小),从而帮助Bessie。
要计算字符串X和字符串Y按照重新排列过的字母表顺序来排列的顺序,先找到它们第一个不同的字母X[i]与Y[i],按重排后的字母表顺序比较,若X[i]比Y[i]先,则X的字典序比Y小,即X排在Y前;若没有不同的字母,则比较X与Y长度,若X比Y短,则X的字典序比Y小,即X排在Y前。
输入输出格式
输入格式:
* Line 1: A single line containing N (1 <= N <= 30,000), the number of strings Bessie is playing with.
* Lines 2..1+N: Each line contains a non-empty string. The total
number of characters in all strings will be no more than 300,000. All
characters in input will be lowercase characters 'a' through 'z'. Input
will contain no duplicate strings.
第1行:一个数字N(1 <= N <= 30,000),Bessie正在研究的字符串的数量。
第2~N+1行:每行包含一个非空字符串。所有字符串包含的字符总数不会超过300,000。 输入中的所有字符都是小写字母,即a~z。 输入不包含重复的字符串。
输出格式:
* Line 1: A single line containing K, the number of strings that could be lexicographically first.
* Lines 2..1+K: The (1+i)th line should contain the ith string that
could be lexicographically first. Strings should be output in the same
order they were given in the input.
第1行:一个数字K,表示按重排后的字母表顺序排列的字符串有多少可以排在第一个数量。
第2~K+1行:第i+1行包含第i个按重排后的字母表顺序排列后可以排在第一个的字符串。字符串应该按照它们在输入中的顺序来输出。
输入输出样例
4
omm
moo
mom
ommnom
2
omm
mom
说明
The example from the problem statement.
Only "omm" and "mom" can be ordered first.
样例即是题目描述中的例子,只有“omm”和“mom”在各自特定的字典序下可以被排列在第一个。
Solution:
本题trie树+拓扑排序。
首先,我们不难想到若一个字符串是另一个字符串的前缀,则后者一定不可能排在第一个,那么这种情况直接可以trie树判掉,然后我们可以枚举每个字符串作为第一个串,在trie树中查询该串时对于与当前指针同层次的指针建字符连向字符的有向边并统计入度(表示当前指针所带表字符要比同层次的其它指针表示的字符字典序小),然后就能得到一张图,只要该图无环就说明该字符串可行,需要判环于是想到在该图上跑拓扑排序,若能使每个字符的入度均为0说明可行,否则不行。
代码:
#include<bits/stdc++.h>
#define il inline
#define ll long long
#define For(i,a,b) for(int (i)=(a);(i)<=(b);(i)++)
#define Bor(i,a,b) for(int (i)=(b);(i)>=(a);(i)--)
using namespace std;
const int N=,M=;
int trie[M][],tot=;
int n,ans,to[M],net[M],rd[N],h[N],cnt;
char s[][];
bool end[M],ct[M]; il void cler(){cnt=;memset(h,,sizeof(h));memset(rd,,sizeof(rd));} il void add(int u,int v){to[++cnt]=v,net[cnt]=h[u],h[u]=cnt,rd[v]++;} il bool bfs(){
queue<int>q;
For(i,,) if(!rd[i]) q.push(i);
while(!q.empty()){
int u=q.front();q.pop();
for(int i=h[u];i;i=net[i])
if(--rd[to[i]]==)q.push(to[i]);
}
For(i,,) if(rd[i])return ;
return ;
} il void insert(char *s){
int len=strlen(s),p=,x;
For(i,,len-){
x=s[i]-'a';
if(!trie[p][x])trie[p][x]=++tot;
p=trie[p][x];
}
end[p]=;
} il bool search(char *s){
cler();
int len=strlen(s),p=,x;
For(i,,len-){
x=s[i]-'a';
if(end[p])return ;
For(j,,) if(x!=j&&trie[p][j]) add(x+,j+);
p=trie[p][x];
}
return ;
} int main(){
scanf("%d",&n);
For(i,,n) scanf("%s",s[i]),insert(s[i]);
For(i,,n) if(search(s[i])&&bfs()) ct[i]=,ans++;
printf("%d\n",ans);
For(i,,n) if(ct[i]) puts(s[i]);
return ;
}
P3065 [USACO12DEC]第一!First!的更多相关文章
- [luogu P3065] [USACO12DEC]第一!First!
		
[luogu P3065] [USACO12DEC]第一!First! 题目描述 Bessie has been playing with strings again. She found that ...
 - 洛谷P3065 [USACO12DEC]第一!First!(Trie树+拓扑排序)
		
P3065 [USACO12DEC]第一!First! 题目链接:https://www.luogu.org/problemnew/show/P3065 题目描述 Bessie一直在研究字符串.她发现 ...
 - Luogu P3065 [USACO12DEC]第一!First!【字典树/拓扑排序】By cellur925
		
题意:给你许多字符串,你可以改变字母序大小,问有哪些字符串可能成为字典序最小的字符串. 我们考虑把这些字符串都塞到\(trie\)树上.之后检索每一个字符串的时候,我们看和他同一层的地方是否有字符,如 ...
 - [USACO12DEC]第一!First! (Trie树,拓扑排序)
		
题目链接 Solution 感觉比较巧的题啊... 考虑几点: 可以交换无数次字母表,即字母表可以为任意形态. 对于以其他字符串为前缀的字符串,我们可以直接舍去. 因为此时它所包含的前缀的字典序绝对比 ...
 - [USACO12DEC]第一!First!(字典树,拓扑排序)
		
[USACO12DEC]第一!First! 题目描述 Bessie has been playing with strings again. She found that by changing th ...
 - [bzoj3012][luogu3065][USACO12DEC][第一!First!] (trie+拓扑排序判环)
		
题目描述 Bessie has been playing with strings again. She found that by changing the order of the alphabe ...
 - 【[USACO12DEC]第一!First!】
		
一个串不能成为第一的情况有两种 另外一个单词是它的前缀 在分配字母表大小关系的时候出现了矛盾的情况 第一种很好判断,一旦我们在一个单词没有匹配完之前遇到一个结束标志,那么就说明另外一个单词是它的前缀 ...
 - [Luogu3065][USACO12DEC]第一!First!
		
题目描述 Bessie has been playing with strings again. She found that by changing the order of the alphabe ...
 - P3065 [USACO12DEC]First! G
		
题意描述 [USACO12DEC]First! G 不错的一道题. 给你 \(N\) 个字符串,要求你求出可能的字典序最小的字符串. 对于 可能的最小的字符串,你可以任意排列 \(26\) 个字母,使 ...
 
随机推荐
- Mac iTem2 自动登录服务器配置
			
假设你要连接的服务器地址为123.123.123.123,端口号为8888,用户名为root,密码为mimamima 编写shell文件"login_server.sh",并放置于 ...
 - fastDFS 分布式文件系统应用
			
环境准备 使用的系统软件 名称 说明 centos 7.x libfatscommon FastDFS分离出的一些公用函数包 FastDFS FastDFS本体 fastdfs-nginx-modul ...
 - spring-boot日志操作
			
SpringBoot Logback日志配置 Logback的配置介绍: 1.Logger.appender及layout Logger作为日志的记录器,把它关联到应用的对应的context上后,主要 ...
 - python 解决url编译
			
from urllib import parse s = parse.unquote("%7B%22name%22%3A%22joe%22%2C%22age%22%3A%2223%22%7D ...
 - iOS - Foundation相关
			
1.NSString A.创建的方式: stringWithFormat:格式化字符串 ,创建字符串对象在堆区域 @"jack& ...
 - VIN码识别(车架号识别)在二手车交易中的应用
			
最新数据统计,2015年,中国卖出2110万辆新车,相比之下,美国卖出去了1740辆新车.然而,如果算上二手车,美国的汽车市场销量将扩展到4000多辆,而中国的乘用车才不到3000万辆. 销售总额上, ...
 - Linux命令应用大词典-第4章 目录和文件操作
			
4.1 pwd:显示(打印)当前工作目录路径 4.2 cd:更改工作目录路径 4.3 ls: 列出目录和文件信息: 4.4 dir:列出目录或文件信息: 4.5 dirs:显示目录列表: 4.6 to ...
 - 第五模块·WEB开发基础-第2章JavaScript基础
			
第1章 JavaScript基础 01-JavaScript历史介绍 02-JavaScript的组成 03-JavaScript的引入方式 04-变量的使用 05-基本数据类型(一) 06-基本数据 ...
 - phpanalysis提取关键字
			
最近在开发一个文章模块功能,设计那边提出要给文章生成对应标签,用于文章关联推送,这里和大家分享一下实现过程: 这里需要用到PHPAnalysis,下载链接如下 链接:https://pan.baidu ...
 - 【view】 视图组件说明
			
view 是视图容器,可用于包裹其它组件或文本内容. 原型: <view hover-class="[String]" hover-stop-propagation=&quo ...