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

    你可能感兴趣的文章
    Node响应中文时解决乱码问题
    查看>>
    node基础(二)_模块以及处理乱码问题
    查看>>
    node安装卸载linux,Linux运维知识之linux 卸载安装node npm
    查看>>
    node安装及配置之windows版
    查看>>
    Node实现小爬虫
    查看>>
    Node提示:error code Z_BUF_ERROR,error error -5,error zlib:unexpected end of file
    查看>>
    Node提示:npm does not support Node.js v12.16.3
    查看>>
    Node搭建静态资源服务器时后缀名与响应头映射关系的Json文件
    查看>>
    Node服务在断开SSH后停止运行解决方案(创建守护进程)
    查看>>
    node模块化
    查看>>
    node模块的本质
    查看>>
    node环境下使用import引入外部文件出错
    查看>>
    node环境:Error listen EADDRINUSE :::3000
    查看>>
    Node的Web应用框架Express的简介与搭建HelloWorld
    查看>>
    Node第一天
    查看>>
    node编译程序内存溢出
    查看>>
    Node读取并输出txt文件内容
    查看>>
    node防xss攻击插件
    查看>>
    noi 1996 登山
    查看>>
    noi 7827 质数的和与积
    查看>>