LeetCode3月17周赛(100236. 统计以给定字符开头和结尾的子字符串总数 )

100236. 统计以给定字符开头和结尾的子字符串总数


在这里插入图片描述

代码

class Solution {
    // 方法接收一个字符串s和一个字符c,返回s中包含字符c的所有子字符串的数量
    public long countSubstrings(String s, char c) {
        long cnt = 0; // 用于计数字符串s中字符c出现的次数
        // 遍历字符串s中的每个字符,如果字符与c相同,则cnt增加
        for (char i : s.toCharArray()) {
            if (i == c) {
                cnt++;
            }
        }
        // 如果字符c在字符串s中没有出现,或者只出现了一次,直接返回cnt
        // 因为如果没有出现,那么不可能形成子字符串;如果只出现一次,那么只有一个单字符子字符串
        if (cnt == 0 || cnt == 1) return cnt;

        // 如果字符c在字符串s中出现了至少两次,计算包含字符c的所有可能子字符串的数量
        // 这里使用组合数学的概念:
        // 1. cnt个c可以形成cnt*(cnt-1)/2个包含至少两个c的子字符串
        // 2. 加上cnt个单独的c字符本身,总数为cnt*(cnt-1)/2 + cnt
        return cnt * (cnt - 1) / 2 + cnt;
    }
}

解释

这个方法首先计算字符串s中特定字符c出现的总次数cnt。然后,基于cnt的值,使用组合数学的原理来计算所有可能的子字符串数量。如果cnt为0或1,直接返回cnt,因为0表示没有包含字符c的子字符串,1表示只有一个单字符子字符串。

如果c出现了2次或以上,那么可以形成的子字符串数量包括:

  • 所有包含至少两个c的子字符串的数量,这可以通过cnt * (cnt - 1) / 2来计算。这是因为从cnt个位置选择2个位置作为子字符串的起始和结束位置的方法数(即组合数C(cnt, 2))。
  • 加上每个单独的c自身作为子字符串,即额外的cnt次。

通过这种方式,countSubstrings方法能够高效地计算出包含特定字符c的所有可能子字符串的数量。

  • 15
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值