【JZOJ3852】【NOIP2014八校联考第2场第2试9.28】单词接龙(words)

DDD

Bsny从字典挑出N个单词,并设计了接龙游戏,只要一个单词的最后两个字母和另一个单词的前两个字母相同,那么这两个单词就可以有序的连接起来。
Bsny想要知道在所给的所有单词中能否按照上述方式接龙组成一个单词环(可能是多个),若能,求所有环的环中单词平均长度最大值。
100%的数据:n≤100000,每个单词长度不超过1000。输入数据比较大,C/C++的同学用scanf输入。

Slai

容易看出,有用的东西仅仅只是每个单词的头两个字母以及尾两个字母。
这两个字母组合最多只有 262 种。
所以容易把这些单词抽象为一个最多 262 个点的有向图:
其中把字母组合看作,把单词看作边的长度单词的长度


在图上,我们要找一个平均长度最长的环。
关于求平均数的问题,我们考虑二分。
对于二分答案 mid ,给所有边的长度减去 mid
并且在现在这个图中利用spfa判断是否存在正权环。
存在那么 mid 太大,不存在则 mid 太小。


spfa判环:
如果一个点的进队次数超过了总顶点数,那么原图一定存在环。
改变不等号的方向可以分别判断正环和负环。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值