EternalLBZ 2024-03-23 19:56 采纳率: 7.7%
浏览 0

E - 单一字符串dscg

如果一个字符串仅有一个字母组成,那称这个字符串为单一字符串。比如 “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,仅由大写字母组成。
输出
一个整数,不同的单一字符串个数。c++

  • 写回答

3条回答 默认 最新

  • 码农阿豪@新空间代码工作室 Java领域优质创作者 2024-03-23 19:56
    关注
    让阿豪来帮你解答,本回答参考chatgpt3.5编写提供,如果还有疑问可以评论或留言
    算法思路: 对于一个单一字符串可以从任意位置开始,向左右两侧扩散得到所有的子串,因此可以枚举每个字符作为单一字符串的起点,统计扩散的子串中不同的单一字符串个数。 代码实现: 使用 set 存储不同的单一字符串。对于每个起点,向左右两侧扩散得到所有的子串,如果子串中的所有字符都与起点相同,则将该子串加入 set 中。 时间复杂度为 O(n^2log n),空间复杂度为 O(nlog n)。 C++代码:
    评论

报告相同问题?

问题事件

  • 创建了问题 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单元闪烁效果失灵