(FJWC2020) DTOJ 4686. 字符串

2024-03-08 23:32
文章标签 字符串 dtoj fjwc2020 4686

本文主要是介绍(FJWC2020) DTOJ 4686. 字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题意

你喜欢字符串。有人送了你一个仅含小写字母的字符串。
由于你是一名优秀的 OIer,所以你决定对这个字符串展开研究。
定义两个字符串是相似的,当且仅当存在至多一个 i i i,使得这两个字符串中只有第 i i i 个字母不同。
你取出了这个字符串中所有长度为 m m m 的子串。你想知道,对于每个长度为 m m m 的子串,有多少个其它长度为 m m m 的子串与它相似。

子任务 1 ( 10 % ) 1(10\%) 1(10%) 1 ≤ n ≤ 500 1 \leq n \leq 500 1n500
子任务 2 ( 20 % ) 2(20\%) 2(20%) 1 ≤ n ≤ 5000 1 \leq n \leq 5000 1n5000
子任务 3 ( 30 % ) 3(30\%) 3(30%) 1 ≤ n ≤ 1 0 5 , 1 ≤ m ≤ 100 1 \leq n \leq 10^5,1\leq m \leq 100 1n105,1m100
子任务 4 ( 40 % ) 4(40\%) 4(40%):无特殊限制。
对于 100 % 100\% 100% 的数据, 1 ≤ n ≤ 1 0 5 , 1 ≤ m ≤ n 1 \leq n \leq 10^5,1\leq m \leq n 1n105,1mn

题解

考虑转化两个子串相似的条件: l c p lcp lcp l c s lcs lcs的长度和不小于 m − 1 m-1 m1,这样就可将条件转化为前缀和后缀的限制,方便处理。
于是对正、反串各建一个 S A M ( A , B ) SAM(A,B) SAMA,B,条件就转化为两串前缀在 A A A上的 m x + mx+ mx+两串后缀在 B B B上的 m x mx mx不超过 m − 1 m-1 m1
考虑在 A A A上枚举 l c a lca lca,计算子树内每一个点的贡献,发现一个点对后面的贡献是单点修改,区间查询,树状数组维护即可;但这样会漏掉后面对前面的贡献,再用一个树状数组维护区间加,单点查询。计算过程用dsu on tree的思想,轻子树可以随便常数次遍历,重子数只能往下递归一次,注意一下哪些操作需要 l c a lca lca的信息,什么时候需要清空即可,效率 O ( n l o g 2 n ) O(nlog^{2}n) O(nlog2n)

这篇关于(FJWC2020) DTOJ 4686. 字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

python修改字符串值的三种方法

《python修改字符串值的三种方法》本文主要介绍了python修改字符串值的三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录第一种方法:第二种方法:第三种方法:在python中,字符串对象是不可变类型,所以我们没办法直接

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

C#中字符串分割的多种方式

《C#中字符串分割的多种方式》在C#编程语言中,字符串处理是日常开发中不可或缺的一部分,字符串分割是处理文本数据时常用的操作,它允许我们将一个长字符串分解成多个子字符串,本文给大家介绍了C#中字符串分... 目录1. 使用 string.Split2. 使用正则表达式 (Regex.Split)3. 使用

Java中JSON字符串反序列化(动态泛型)

《Java中JSON字符串反序列化(动态泛型)》文章讨论了在定时任务中使用反射调用目标对象时处理动态参数的问题,通过将方法参数存储为JSON字符串并进行反序列化,可以实现动态调用,然而,这种方式容易导... 需求:定时任务扫描,反射调用目标对象,但是,方法的传参不是固定的。方案一:将方法参数存成jsON字

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

C和指针:字符串

字符串、字符和字节 字符串基础 字符串就是一串零个或多个字符,并且以一个位模式为全0的NUL字节结尾。 字符串长度就是字符串中字符数。 size_t strlen( char const *string ); string为指针常量(const修饰string),指向的string是常量不能修改。size_t是无符号数,定义在stddef.h。 #include <stddef.h>

PHP字符串全排列

方法一: $str = 'abc';$a =str_split($str);perm($a, 0, count($a)-1);function perm(&$ar, $k, $m) {if($k == $m){ echo join('',$ar), PHP_EOL;}else {for($i=$k; $i<=$m; $i++) {swap($ar[$k], $ar[$i]);perm($ar

PHP7扩展开发之字符串处理

前言 这次,我们来看看字符串在PHP扩展里面如何处理。 示例代码如下: <?phpfunction str_concat($prefix, $string) {$len = strlen($prefix);$substr = substr($string, 0, $len);if ($substr != $prefix) {return $prefix." ".$string;} else