博客
关于我
2021牛客寒假算法基础集训营3 F.匹配串
阅读量:169 次
发布时间:2019-02-28

本文共 1292 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要判断给定的多个模式串是否存在一个共同的匹配串,使得所有模式串在替换#后的结果完全相同。如果存在这样的匹配串,我们需要判断其数量是否为有限值或无穷值。

方法思路

  • 问题分析:每个模式串包含小写字母和至少一个#,其中#可以被替换为任意长度的任意小写字母字符串。我们需要找到所有模式串在替换#后的结果相同的情况。
  • 关键观察:对于所有模式串,替换后的结果必须具有相同的前缀和后缀。前缀是指模式串开头的连续小写字母部分,后缀是指模式串结尾的连续小写字母部分。
  • 算法步骤
    • 对于每个模式串,计算其前缀(从开始到第一个#之前的所有字符)和后缀(从最后一个#之后到末尾的所有字符)。
    • 比较所有模式串的前缀是否相同。
    • 比较所有模式串的后缀是否相同。
    • 如果前缀和后缀都相同,则中间的#部分可以被统一替换,导致无穷多个匹配串,输出-1。否则,输出0。
  • 解决代码

    import sys
    def main():
    n = int(sys.stdin.readline())
    prefix = []
    suffix = []
    for _ in range(n):
    s = sys.stdin.readline().strip()
    # 计算前缀
    pre = []
    for c in s:
    if c == '#':
    break
    pre.append(c)
    pre_str = ''.join(pre)
    prefix.append(pre_str)
    # 计算后缀
    i = len(s) - 1
    while i >= 0 and s[i] != '#':
    i -= 1
    suffix_str = s[i+1:]
    suffix.append(suffix_str)
    # 检查前缀是否都相同
    if len(set(prefix)) != 1:
    print(0)
    else:
    # 检查后缀是否都相同
    if len(set(suffix)) != 1:
    print(0)
    else:
    print(-1)
    if __name__ == "__main__":
    main()

    代码解释

  • 读取输入:使用sys.stdin.readline读取输入,处理大量数据会更高效。
  • 计算前缀和后缀:对于每个模式串,计算其前缀和后缀。前缀是从开始到第一个#之前的所有字符,后缀是从最后一个#之后到末尾的所有字符。
  • 检查前缀和后缀:将所有模式串的前缀和后缀存储在列表中,检查这些列表是否有相同的值。如果有,则输出-1,表示存在无穷多个匹配串;否则,输出0。
  • 转载地址:http://nhjj.baihongyu.com/

    你可能感兴趣的文章
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>
    Network 灰鸽宝典【目录】
    查看>>
    NetworkX系列教程(11)-graph和其他数据格式转换
    查看>>
    Networkx读取军械调查-ITN综合传输网络?/读取GML文件
    查看>>
    network小学习
    查看>>
    Netwox网络工具使用详解
    查看>>
    Net与Flex入门
    查看>>
    net包之IPConn
    查看>>
    Net操作配置文件(Web.config|App.config)通用类
    查看>>
    Neutron系列 : Neutron OVS OpenFlow 流表 和 L2 Population(7)
    查看>>
    New Relic——手机应用app开发达人的福利立即就到啦!
    查看>>
    NFinal学习笔记 02—NFinalBuild
    查看>>
    NFS
    查看>>
    NFS Server及Client配置与挂载详解
    查看>>
    NFS共享文件系统搭建
    查看>>
    nfs复习
    查看>>
    NFS安装配置
    查看>>
    NFS的安装以及windows/linux挂载linux网络文件系统NFS
    查看>>
    NFS的常用挂载参数
    查看>>