zoukankan      html  css  js  c++  java
  • 【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判环:
    如果一个点的进队次数超过了总顶点数,那么原图一定存在环。
    改变不等号的方向可以分别判断正环和负环。

  • 相关阅读:
    Android.02.Button
    Android.01. TextView
    Android.00.IDEA中Android开发环境搭建
    Java34.Marven
    CSS 滚动条样式
    不常用的HTML和CSS 记录
    JS 规则
    svg转化成canvas以便生成base64位的图片
    ArcGIS Server 10.1 安装教程
    ArcGis API JS 4.X 本地化部署
  • 原文地址:https://www.cnblogs.com/hiweibolu/p/6714805.html
Copyright © 2011-2022 走看看