牛客周赛 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);
}

思路

直接遍历一遍,求 chi!=chi+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的位置,继续找即可。

相关推荐
INGNIGHT7 分钟前
984.不含 AAA 或 BBB 的字符串(贪心)
开发语言·算法·leetcode
飞天狗1119 分钟前
2025第十六届蓝桥杯c/c++B组国赛题解
c语言·c++·算法·蓝桥杯
超梦dasgg15 分钟前
Tarjan算法解 强连通分量 & 循环依赖
算法·深度优先·图论
散峰而望37 分钟前
【算法练习】算法练习精选:从 Phone numbers 到 Decrease,覆盖字符串、模拟、图论思维题
数据结构·c++·算法·贪心算法·github·动态规划·图论
人道领域43 分钟前
【LeetCode刷题日记】538.把二叉搜索树转换为累加树
java·开发语言·后端·算法·leetcode
Lsk_Smion1 小时前
力扣实训 _ [33].搜索旋转排序数组 _ [92].翻转链表Ⅱ
java·数据结构·算法
MrZhao4001 小时前
多 Agent 协作与通信:MessageBus 最小实现
算法
Zhang~Ling1 小时前
二叉搜索树(BST)详解:插入、删除、查找与 Key/Value 实战场景
数据结构·c++·算法
8Qi81 小时前
LeetCode 76. 最小覆盖子串(Minimum Window Substring)
数据结构·算法·leetcode·滑动窗口·哈希表
weixin_BYSJ19871 小时前
springboot旅游管理系统04470(附源码+开发文档+部署教程)
java·spring boot·python·算法·django·flask·旅游