EternalLBZ 2024-03-23 20:05 采纳率: 7.7%
浏览 1

E - 单一字符串iuytr

如果一个字符串仅有一个字母组成,那称这个字符串为单一字符串。比如 “A”、“BB”、“CC”为单一字符串,“AB”、“ABC”就不是。
给定一个长度为
n 的字符串
s,在它的所有子串中,有多少个不同的单一字符串? 比如字符串 “AABA”,有子串 “A”、“A”、“B”、“A”、“AA”、“AB”、“BA”、“AAB”、“ABA”、“AABA”。其中不同的单一字符串为 “A”、“B”、“AA” 三个。
输入
第一行一个正整数
(1≤n≤2∗10^5),表示字符串的长度。
第二行一个长度为
n 的字符串
s,仅由大写字母组成。
输出
一个整数,不同的单一字符串个数。
时间限制1秒c++

  • 写回答

2条回答 默认 最新

  • 码农阿豪@新空间代码工作室 Java领域优质创作者 2024-03-23 20:06
    关注
    让阿豪来帮你解答,本回答参考chatgpt3.5编写提供,如果还有疑问可以评论或留言
    思路: 由于题目要求统计所有子串中不同的单一字符串个数,我们可以考虑枚举所有子串,并将其中的单一字符串记录下来,最后再去重统计个数。 在枚举子串时,可以用两个指针$i,j$分别表示子串的起点和终点,用一个set(或unordered_set)记录当前子串中出现过的单一字符串,每次向右移动$j$并将$s[j]$加入set中,同时为了避免重复,每次向左移动$i$前也需要将$s[i]$从set中删除。如果每次从set中删除和添加元素的时间复杂度都是$O(1)$的话,遍历所有子串的时间复杂度就是$O(n^2)$。 然而,set的删除和添加操作的时间复杂度是$O(log\ n)$的,若使用set的话,就会导致算法的时间复杂度达到$O(n^2\ log\ n)$。因此我们需要采用一些方式,使得删除和添加操作的时间复杂度为$O(1)$,而unordered_set可以做到这一点。最终的时间复杂度就是$O(n^2)$的。 代码实现:
    评论

报告相同问题?

问题事件

  • 创建了问题 3月23日

悬赏问题

  • ¥15 python怎么在已有视频文件后添加新帧
  • ¥20 虚幻UE引擎如何让多个同一个蓝图的NPC执行一样的动画,
  • ¥15 fluent里模拟降膜反应的UDF编写
  • ¥15 MYSQL 多表拼接link
  • ¥15 关于某款2.13寸墨水屏的问题
  • ¥15 obsidian的中文层级自动编号
  • ¥15 同一个网口一个电脑连接有网,另一个电脑连接没网
  • ¥15 神经网络模型一直不能上GPU
  • ¥15 pyqt怎么把滑块和输入框相互绑定,求解决!
  • ¥20 wpf datagrid单元闪烁效果失灵