Collapsing Strings

做这道题目的时候学CDQ和整体二分学成傻逼了是吧?我寻思着非要把一整个数组传进去操作,明明一个一个考虑不就好了真的烦躁

题外话,做这道题目的时候,探索出来一个东西,vector要放字符串的话,template可以写char *

最开始的想法是编写一个函数work(vector<char *> a,vector<char *> b),然后 a a a代表的是 s i s_i si b b b代表的是 s j s_j sj

考虑统计答案,我们枚举 26 26 26个字符中的某一个,然后把 a a a b b b中以此字符开头/结尾的字符串找出来,递归处理这些字符串的贡献,然后这些字符串与其他的字符串的贡献可以 O ( 1 ) O(1) O(1)算出

但是这个代码非常难写,而且有vector递归,直接爆栈

然后看到了前缀后缀,想到了trie,故转换思路,把所有字符串倒序插入建立trie树,然后把所有字符串放到一个vector中传到递归函数里面类似地统计答案,仍然会MLE

然后想到给每个trie节点都开一个vector,放在全局变量里面,但是好像即使什么元素都没有放,仍然会MLE

好煞笔啊真的,为什么一定要一次性处理所有字符串呢?真的是CDQ和整体二分学傻了,一个一个处理统计答案就好了

另外做这道题目的时候,一定要慢慢地把细节想清楚,不然也会写很久

update 2024.7.14

重新做一遍这个题目,很快就做出来了,所以说脑子别晕就好了

当然也可以不推这个公式,在trie树上维护一些额外的信息就好了(只不过推了这个公式更容易看出前后缀所以要利用trie树)

但是可以好好想想为什么 t o t tot tot之和就是答案(提示:从每个字符串的贡献角度考虑),然后可以记住这个trie的操作,查询公共前后缀长度就可以用

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. range-based for循环 range-based for循环是C++11引入的一种新的循环结构,它可以简化对容器和数组等数据结构的遍历。其语法形式如下: ``` for (declaration : range_expression) statement ``` 其中,declaration是一个变量声明,range_expression是一个表示要遍历的数据结构的表达式,statement是循环体中要执行的语句。 range_expression可以是任何具有begin()和end()成员函数的对象,包括STL容器、原生数组、指针等。循环的过程中,declaration将会被自动初始化为range_expression中的每个元素,从而实现遍历。 2. 结构化绑定(structured bindings) 结构化绑定是C++17引入的一种新的语言特性,它可以将一个复杂的数据结构拆分成若干个变量,使得代码更加简洁易读。其语法形式如下: ``` auto [var1, var2, ...] = expression; ``` 其中,var1、var2等表示要绑定的变量名,expression表示要进行拆分的数据结构。 结构化绑定可以用在任何支持解包的上下文中,例如函数返回值、for循环中的迭代器等。 3. 引用折叠(reference collapsing) 引用折叠是C++11引入的一种语言特性,用于规定C++中引用类型的组合方式。其规则如下: - 对于右值引用(Rvalue Reference,T&&),无论与左值引用还是右值引用相结合,都会得到右值引用类型。 - 对于左值引用(Lvalue Reference,T&),在不使用模板特化的情况下,左值引用与左值引用相结合得到左值引用,右值引用与左值引用结合得到右值引用类型。 - 在使用模板特化的情况下,引用折叠规则会发生变化。 引用折叠的主要作用是简化模板编程中的引用类型推导。它也是许多新特性的基础,例如完美转发、可变参数模板等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值