【bzoj3012】[Usaco2012 Dec]First(题解)

该博客介绍了如何解决Usaco2012 December竞赛中的First问题,涉及字符串字典序的概念。通过分析,博主提出利用Trie数据结构和拓扑排序来找出能排在首位的字符串,并提供了相应的算法思路和代码实现。
摘要由CSDN通过智能技术生成

题目描述


小x在学习字符串的时候,对字符串的字典序很感兴趣。
他现在有N个字符串,他想知道,如何安排不同的字典序,能够让那些字符串按照某种字典序能够排在N个字符串的第一个。
比如有四个字符串:”omm”, “moo”, “mom”, 和”ommnom”。如果字典序是标准字典序,”mom”排在第一个。如果按照”abcdefghijklonmpqrstuvwxyz”这个顺序排,”omm”排在第一个,无论你怎么安排,字符串”moo”和”ommnom”都不可能在第一个。


输入格式


第一行一个整数N(1 <= N <= 30,000),表示有N个字符串。
接下来N行,每行一个字符串。保证字符串中只包含小写字符。
数据保证N个字符串的字符总数不会超过300000个字符。
输入数据保证不会出现两个相同的字符串。


输出格式

第一行一个整数K,表示有K个字符串可以以某种顺序排在N个字符串中首位。
接下来K行,每行一个字符串,表示某个符合条件的字符串。
K行字符串的顺序按照输入顺序输出。

这里写图片描述

分析
首先我们要知道,一个字符串要想排在第一个,她就应该没有字符串前缀。
其次,对于有公共前缀的,其他的下一个字母的优先级就要在这一个字母优先级的后面.也就是说,在同一个父亲下,这个儿子要比其他兄弟的优先度高。那么我们就连一条有向边,设为x->y表示x的优先度比y高。如果出现环就说明有矛盾啊,冲突了,就不可以了。
那么上面的操作我们就可以用Trie来做了。
然后连一条边topsort就ok了;

代码:

#include<bits/stdc++.h>
using namespace std;
const 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值