肥猪的钢琴床

题目描述
链接:https://ac.nowcoder.com/acm/contest/9692/A
来源:牛客网

肥猪很喜欢睡懒觉,与此同时肥猪十分喜欢买各种各样神奇的床。

今天肥猪买了一张很宽很宽的钢琴床,肥猪就在上面滚来滚去。
这张钢琴床十分的有趣,因为它被分为n个部分,每一个部分是凸起来或者凹下去的,可是肥猪十分不喜欢相邻两个位置高低不同,因为他会滚不过去。
肥猪从小就很喜欢这样的一句谚语:猪往高处走,水往低处流,所以肥猪很喜欢凸起来的部分而不喜欢凹下去的部分。
现在肥猪可以把床中的某一些部分拿走,以让剩余部分所有凸起来的部分都是连起来的,这样肥猪就会很开心,因为他又可以滚来滚去了。
肥猪希望移除的部分最少

我们假设0表示某一个位置是凹下去的,1表示某一个位置是凸起来的。

那么
0
1
00111
01111000
11100
都是肥猪喜欢的钢琴床,因为所有凸起来的部分都是连续的

如果是
101
010011
1111101
就是肥猪不喜欢的钢琴床,因为所有凸起来的部分不是连续的
对于第一张床,肥猪可以把第二个位置拿走,这样床就变成了11。
对于第二张床,肥猪可以把第二个位置拿走,这样床就变成了00011。

输入详情

读入一共有两行,第一行只有一个正整数数n,表示钢琴床有n个部分。
第二行由一个01串组成

  • n<=1000000
  • 保证01串的长度为n
    输出详情
    输出一个正整数表示肥猪最少要拿走的部分的数量
#include <iostream>
#include <cstdio>
using namespace std;
int main()
{
    char sz[1000005];//数组开大点防止溢出; 
    int n;
    cin>>n;
    cin>>sz;
    int sum=0;
    for(int i=0;i<n;i++)
    if(sz[i]=='1')//统计一共有多少1; 
    sum++;
    int m=0;
    int s=0;
    for(int i=0;i<n;i++)
    {
       if(sz[i]=='1')
        {
            s++;
        }
        else if(sz[i]=='0')
        {
            s--;
        }
        if(s<0)//找出字符串中最长的连续1的个数; 
        s=0;
        if(s>m)
        m=s;
    }
    cout<<sum-m;//输出单独要提出的一的次数; 
    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值