博客
关于我
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/

    你可能感兴趣的文章
    noi 1996 登山
    查看>>
    noi 7827 质数的和与积
    查看>>
    NOI2010 海拔(平面图最大流)
    查看>>
    NOIp2005 过河
    查看>>
    NOIP2011T1 数字反转
    查看>>
    NOIP2014 提高组 Day2——寻找道路
    查看>>
    NOIp模拟赛二十九
    查看>>
    Nokia5233手机和我装的几个symbian V5手机软件
    查看>>
    Non-final field ‘code‘ in enum StateEnum‘
    查看>>
    none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
    查看>>
    None还可以是函数定义可选参数的一个默认值,设置成默认值时实参在调用该函数时可以不输入与None绑定的元素...
    查看>>
    NOPI读取Excel
    查看>>
    NoSQL&MongoDB
    查看>>
    NoSQL介绍
    查看>>
    Notadd —— 基于 nest.js 的微服务开发框架
    查看>>
    Notepad ++ 安装与配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    Notepad++在线和离线安装JSON格式化插件
    查看>>
    notepad++最详情汇总
    查看>>
    notepad如何自动对齐_notepad++怎么自动排版
    查看>>
    Notification 使用详解(很全
    查看>>