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

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

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

方法思路

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

    import sysdef 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
    查看>>
    NetworkX系列教程(11)-graph和其他数据格式转换
    查看>>
    Networkx读取军械调查-ITN综合传输网络?/读取GML文件
    查看>>
    Net与Flex入门
    查看>>
    net包之IPConn
    查看>>
    NFinal学习笔记 02—NFinalBuild
    查看>>
    NFS共享文件系统搭建
    查看>>
    nfs复习
    查看>>
    NFS网络文件系统
    查看>>
    nft文件传输_利用remoting实现文件传输-.NET教程,远程及网络应用
    查看>>
    ng 指令的自定义、使用
    查看>>
    Nginx
    查看>>
    nginx + etcd 动态负载均衡实践(二)—— 组件安装
    查看>>
    nginx + etcd 动态负载均衡实践(四)—— 基于confd实现
    查看>>
    Nginx + Spring Boot 实现负载均衡
    查看>>
    Nginx + uWSGI + Flask + Vhost
    查看>>
    Nginx - Header详解
    查看>>
    Nginx Location配置总结
    查看>>
    Nginx Lua install
    查看>>