智算之道2020第一场比赛B题

本文深入探讨了一种针对特定串操作的算法实现,重点讲解了如何通过遍历字符串,判断并计算连续字符序列的操作次数,特别关注于连续1和0的序列处理。文章详细介绍了算法的逻辑流程,包括特殊情况的处理,如全1串和结束符的影响,以及如何优化代码以准确计算所需操作的总次数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述
1、该该我首先判断从开始是否有连续的1,如果有这一部分次数+1就能全部关掉,如果没有次数不变。
2、然后就是通常情况,一段连续的0+一段连续的1算作一部分,一部分需要两次即可全部关闭。
3、因为我的代码逻辑,只有在连续的1后出现了0才会将前面的算作一部分,所以当最后一个是1时他不会增加,所以在结尾要加上一个判断,判断最后一位是不是1,如果是1,次数增加。
4、还有一种情况,就是全是1的时候,这个时候第一次判断就已经完成了,但是我最后一个判定会加2,所以我又添加了一个状态量,用于判断是不是全是1,如果全是1(第一次判断就能得到)就改为0,当该状态量为1时候最后一个判断才生效。

#include<iostream>

using namespace std;

int main()
{
    int n;
    cin>>n;
    string a;
    cin>>a;
    int num=0;
    int x=0;
    int j=1;
    for(;x<n;x++)
    {
        if(a[x]=='0')
        {
            if(x!=0)
            num++;
            break;
        }
        if(x==n-1&&a[x]=='1')
        {
            num++;
            j=0;
        }
    }
    x++;
    int i=0;
    for(;x<n;x++)
    {
        if(a[x]=='1')
        {
          i=1;
            continue;
        }
        if(a[x]=='0'&&i)
        {
            num+=2;i=0;
        }
    }
    if(a[n-1]=='1'&&j)
    {
        num+=2;
    }
    cout<<num;
    return 0;
}
LGP1230智力大冲浪 普及/提高- 排序 贪心 标准IO 传统 时间限制 1000ms 内存限制 125MB 通过/尝试次数 252/327 来源 洛谷 目描述 小伟报名参加中央电视台的智力大冲浪节目。本次挑战赛吸引了众多参赛者,主持人为了表彰大家的勇气,先奖励每个参赛者 m m 元。先不要太高兴,因为这些钱还不一定都是你的。接下来主持人宣布了比赛规则: 首先,比赛时间分为 n n 个时段,它又给出了很多小游戏,每个小游戏都必须在规定期限 t i t i ​ 前完成。如果一个游戏没能在规定期限前完成,则要从奖励费 m m 元中扣去一部分钱 w i w i ​ , w i w i ​ 为自然数,不同的游戏扣去的钱是不一样的。当然,每个游戏本身都很简单,保证每个参赛者都能在一个时段内完成,而且都必须从整时段开始。主持人只是想考考每个参赛者如何安排组织自己做游戏的顺序。作为参赛者,小伟很想赢得冠军,当然更想赢取最多的钱!注意:比赛绝对不会让参赛者赔钱! 输入格式 第一行为 m m,表示一开始奖励给每位参赛者的钱; 第二行为 n n,表示有 n n 个小游戏; 第三行有 n n 个数,分别表示游戏 1 1 到 n n 的规定完成期限; 第四行有 n n 个数,分别表示游戏 1 1 到 n n 不能在规定期限前完成的扣款数。 输出格式 输出仅一行,表示小伟能赢取最多的钱。 输入 #1 复制代码 10000 7 4 2 4 3 1 4 6 70 60 50 40 30 20 10 输出 #1 复制代码 9950 提示 对于 100 % 100% 的数据, 1 ≤ n ≤ 500 1≤n≤500, 1 ≤ m ≤ 5 × 1 0 5 1≤m≤5×10 5 , 1 ≤ t i ≤ n 1≤t i ​ ≤n, 1 ≤ w i ≤ 1000 1c++简单代码
最新发布
03-27
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值