力扣每日一题:仅含1的子串数

给定一个只含有0和1的字符串,要求求其中所有由1构成的子串的个数。

思路:

假设当前从[l,r]均是1,那么新加入一个1,新加的子串可以认为是新加的1单独构成,以及和前面[l,r]的1构成,即如果[l,r]的长度为len,则新加一个1,新构成的子串的个数为len+1。因此,只需要找到每一个从1开始的字符串,按照上面的规律进行计算即可。

复制代码
class Solution {
public:
    int numSub(string s) {
        long long ans=0;
        const int mod=1e9+7;//防止超出int范围
        int len=0;//用于保存当前全是1的字符串的总长度
        for(int i=0;i<s.size();i++)
        {
           if(s[i]=='1')
           { 
            len++;
            ans=ans+len;
           }
           else
           {
             len=0;
           }
        }
        return ans%mod;
    }
};
相关推荐
CoovallyAIHub11 小时前
Pipecat:构建实时语音 AI Agent 的开源编排框架,500ms 级端到端延迟
深度学习·算法·计算机视觉
灰色小旋风11 小时前
力扣13 罗马数字转整数
数据结构·c++·算法·leetcode
2301_8101609511 小时前
C++与物联网开发
开发语言·c++·算法
cm65432011 小时前
基于C++的操作系统开发
开发语言·c++·算法
ArturiaZ11 小时前
【day57】
开发语言·c++·算法
CoovallyAIHub11 小时前
Energies | 8版YOLO对8版Transformer实测光伏缺陷检测,RF-DETR-Small综合胜出
深度学习·算法·计算机视觉
Emberone11 小时前
排序:万物皆有序
算法·排序算法
其实秋天的枫11 小时前
2025年12月英语六级真题及答案解析完整版(第一、二、三套全PDF)
经验分享·算法
2401_8747325311 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
2301_7923082511 小时前
C++编译期数学计算
开发语言·c++·算法