LeetCode题目笔记——1759. 统计同构子字符串的数目

news/2024/11/15 6:56:57/

文章目录

    • 题目描述
    • 题目难度——中等
    • 方法一:数学
      • 代码/C++
      • 代码/Python
    • 总结

题目描述

给你一个字符串 s ,返回 s 中 同构子字符串 的数目。由于答案可能很大,只需返回对 109 + 7 取余 后的结果。

同构字符串 的定义为:如果一个字符串中的所有字符都相同,那么该字符串就是同构字符串。

子字符串 是字符串中的一个连续字符序列。

示例 1:

输入:s = “abbcccaa”
输出:13
解释:同构子字符串如下所列:
“a” 出现 3 次。
“aa” 出现 1 次。
“b” 出现 2 次。
“bb” 出现 1 次。
“c” 出现 3 次。
“cc” 出现 2 次。
“ccc” 出现 1 次。
3 + 1 + 2 + 1 + 3 + 2 + 1 = 13
示例 2:

输入:s = “xy”
输出:2
解释:同构子字符串是 “x” 和 “y” 。
示例 3:

输入:s = “zzzzz”
输出:15

提示:

1 <= s.length <= 105
s 由小写字符串组成

题目链接

题目难度——中等

方法一:数学

  根据题目意思,让我们来数一数 “abbcccaa”这个字符串中的子字符串,我们可以将其分为“a”,“bb”,“ccc”,“aa”这几个部分,对“a”,它只有一个字符,同构字符串数也是1,对“bb”,他可以是两个单独的“b”,也可以是连在一起的“bb”,所以一共是3,对“ccc”,它可以是一个“c”,也可以是两个“c”,还可以是三个“c”,所以一共是6,因此,就是像数连续出现的字符可以有多少种情况一样,记一个字符出现的次数为count,那它的同构字符串数量就是(count + 1) * count / 2。

代码/C++

class Solution {
public:int countHomogenous(string s) {long long res = 0, count = 0, mod = 1e9 + 7;char pre = s[0];string ss = s + "E";for(int i = 0; i < ss.size(); i++){if(ss[i] == pre){count++;continue;}res += (1 + count) * count / 2;count = 1;pre = ss[i];}return res % mod;}
};

在这里插入图片描述

代码/Python

class Solution:def countHomogenous(self, s: str) -> int:res = 0for k, g in groupby(s):n = len(list(g))res += (n + 1) * n // 2return res % (10 ** 9 + 7)

总结

  都要遍历一遍字符串,所以时间是O(N),用了一个多的字符串,所以空间是O(N),也可以不用这个多的,在循环退出后外面再算一次计数就可以,那样可以让空间成为O(1)。


http://www.ppmy.cn/news/7039.html

相关文章

Arco 属性

文章目录Arco介绍1. 简介1.1 背景1.2 运行环境1.3 浏览器兼容性2. 设计价值观2.1 清晰2.2 一致2.3 韵律2.4 开放3. 设计原则3.1 及时反馈3.2 贴近现实3.3 系统一致性3.4 防止错误发生3.5 遵从习惯3.6 突出重点3.7 错误帮助3.8 人性化帮助4. 界面总体风格4.1 页面风格4.1.1 主色…

HMS Core 3D流体仿真技术,打造移动端PC级流体动效

移动设备硬件的高速发展&#xff0c;让游戏行业发生翻天覆地的变化&#xff0c;许多酷炫的游戏效果不再局限于电脑端&#xff0c;玩家在移动端就能享受到场景更逼真、画质更清晰、体验更流畅的游戏服务。但由于移动设备算力不足&#xff0c;为了实现真实感的水体效果&#xff0…

求多折线交点

目录 <font color=blue size=4 face="楷体">numpy.isclose<font color=blue size=4 face="楷体">基本思路<font color=blue size=4 face="楷体">代码1<font color=blue size=4 face="楷体">代码2——函数式,…

少儿Python每日一题(2):整数的位数

原题解答 本次的题目如下所示&#xff08;原题出处&#xff1a;蓝桥杯&#xff09;&#xff1a; 【编程实现】 输入一个正整数&#xff0c;输出这个正整数是一个几位数。 输入描述&#xff1a;输入一个正整数 输出描述&#xff1a;输出这个正整数是一个几位数 【样例输入】 12…

分布式理论之分布式事务

写在前面 我们知道&#xff0c;像MySQL的InnoDB存储引擎提供了事务的能力&#xff0c;严格遵守AICD的事务要求&#xff0c;但是在分布式环境中&#xff0c;一个请求会在多个服务实例存在多个事务&#xff0c;如购物&#xff0c;会有订单系统&#xff0c;支付系统&#xff0c;物…

【Python数据可视化】使用geoplotlib绘制地理空间数据

geoplotlib前言一、安装geoplotlib包二、读取csv数据使用1.点密度可视化2.直方图3. Voronoi图总结前言 ❤️❤️希望大家能多多点赞。❤️❤️ 需要数据集的可以评论。 Geoplotlib 是地理空间数据可视化的开源Python库&#xff0c;包含了大量的地理空间可视化操作&#xff0c…

UVM入门和进阶实验0

一. 概述 UVM学习流程仍然按照SV时候的核心流程&#xff0c;即&#xff1a; 如何搭建验证框架验证组件之间的连接和通信如何编写测试用例&#xff0c;继而完成复用和覆盖率的收敛 我们UVM入门和进阶实验0还是同之前SV验证实验0思想一样&#xff0c;让大家通过简单的实验要求…

LeetCode刷题之406 根据身高重建队列(贪心算法)

题目描述 假设有打乱顺序的一群人站成一个队列&#xff0c;数组 people 表示队列中一些人的属性&#xff08;不一定按顺序&#xff09;。每个 people[i] [hi, ki] 表示第 i 个人的身高为 hi &#xff0c;前面 正好 有 ki 个身高大于或等于 hi 的人。 请你重新构造并返回输入数…