牛客周赛 Round 72 <字符串>

<1>小红的01串(一)

复制代码
#include<stdio.h>
#include<string.h>
char ch[100];
int main()
{
    scanf("%s",ch);
    int count=0;
    int len=strlen(ch);
    for(int i=0;i<len-1;i++)
    {
        if(ch[i]!=ch[i+1])
        {
            count++;
        }  
    }
    printf("%d",count);
}

思路

直接遍历一遍,求 ch[i]!=ch[i+1]的个数即可。



<2>小红的01串(二)

复制代码
#include<stdio.h>
#include<string.h>
#define int long long
char c[200010];
signed main()
{ 
        int ans = 0;
        int cnt = 0;
        scanf("%s",c);
        int len = strlen(c);
    for (int i = 0; i < len - 1; i++)
    {
        if (c[i] != c[i + 1])
            cnt++;
        else
        {
            ans += (cnt + 1) * cnt / 2;
                cnt = 0;
        }
    }
    ans += (cnt + 1) * cnt / 2;
    printf("%lld",ans);
}

void solve(){
    string s;
    cin>>s;
    i64 ans=0;
     
    for(int i=0;i<s.size();i++){
        int r=i;
        while(r+1<s.size()&&s[r+1]!=s[r]) r++;
        if(r>i)ans=ans+1LL*(r-i)*(1+r-i)/2;
        i=r;
    }
    cout<<ans<<'\n';
}

思路

如果一个子串满足题意,那么它的所有子串都会满足题意

所以对于每个 i,找到最右边的 j(j>i) 使得该串满足题意,

对于这段区间的答案就是 (j−i)∗(1+j−i)/2

然后找到后把 i跳到 j的位置,继续找即可。

相关推荐
那个村的李富贵20 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿20 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
琹箐21 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia121 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了21 小时前
数据结构之树(Java实现)
java·算法
算法备案代理21 小时前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.1 天前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
野犬寒鸦1 天前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总1 天前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
rainbow68891 天前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法