DTOJ4350. 「十二省联考 2019」字符串问题

2024-03-08 23:48

本文主要是介绍DTOJ4350. 「十二省联考 2019」字符串问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题意:
给一个长度为n的串S,给na个A类S的子串,nb个B类S的子串,由m中支配关系,表示一个A类串支配一个B类串,求最长的由A类串拼接而成的串,满足除最后一个外,每个A类串都存在一个被它支配的B类串,满足该B类串是该A类串下一个A类串的子串。若可以无限长则输出-1。
范围:所有数均<=2e5
题解:
考场:
没有图论思维,因为全世界都会的T1不会做而心态爆炸的我:对每个A类串向它能连向的A类串连边,判断是否有环,有则-1,没有则是一个DAG,DP跑最长路即可。但要怎么判断两个A类串之间是否有连边?还要枚举A所支配的B类串,再哈希判断,这样只有10分。
正解:
先考虑更优秀的暴力,若只在A类串中判断,则判断是否连边时的效率不高。发现一个A类串向另一个A类串连边的条件其实是借助了一个这个A类串支配的串,所以也将B类串作为一个点,A向其支配的B连边,B向是A的前缀的A连边,这样每次枚举B是否为每个A的前缀,O(N*N)就有40分了!
考虑上述算法的复杂度在于B向A连边,而这个条件是B是A的前缀,有什么和前缀有关的数据结构呢?将字符串翻转一下,就变成后缀了,所以考虑后缀自动机。将所有A,B对应到后缀自动机上的点(倍增求即可),B会是哪些串的前缀?显然是后缀树上它的子树的节点上的A!考虑如何用后缀树的结构优化建图,将后缀树的每个点连向它的儿子,这样每个点都有通往它子树的路径。但如何将A,B串和后缀树上的点建立关系?考虑对于在后缀树同一节点上的串,B也会对比它长的A有贡献,故对其长度从大到小排序,每个B都连向他前面的A,一直连到直到下一个B,下一个B也这样做,就可以保证一个节点内的连边关系。不同节点之间,对于前缀的关系,就把每个节点的第一个B连到所有直系儿子的最后一个B,这样保证所有长度小的B都对子树内长度大的A造成贡献,若一个节点内没有B,则新建一个B,反正不会影响权值(选B而不选A作为连接点是为了避免A的权值的影响)。对于支配关系,直接将对应的串相连即可。这样就完美地在O(N)的效率内完成建边了!

这篇关于DTOJ4350. 「十二省联考 2019」字符串问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/788820

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

C# $字符串插值的使用

《C#$字符串插值的使用》本文介绍了C#中的字符串插值功能,详细介绍了使用$符号的实现方式,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录$ 字符使用方式创建内插字符串包含不同的数据类型控制内插表达式的格式控制内插表达式的对齐方式内插表达式中使用转义序列内插表达式中使用

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、