前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Codeforces Round #646 (Div. 2)【B. Subsequence Hate题解】

Codeforces Round #646 (Div. 2)【B. Subsequence Hate题解】

作者头像
_DIY
发布2020-06-02 16:00:04
3200
发布2020-06-02 16:00:04
举报

具体思路已经在代码注释中给出,这里不再赘述。

#include<iostream>
#include<algorithm>
using namespace std;
int t;
string s;
int main()
{
    cin >> t;
    while(t--)
    {
        cin >> s;
        int len = s.size();
        int total0 = 0, total1 = 0;
        for(int i = 0; i < len; i++)
        {
            total0 += (s[i] == '0');
            total1 += (s[i] == '1');
        }
        /**
            最终要把它变成111...000 或者 000...111 或者 全零 或者 全1
        */

        int ans = min(total0, total1);
        int nr0 = 0, nr1 = 0;
        for(int i = 0; i < len; i++)
        {
            nr0 += (s[i] == '0');
            nr1 += (s[i] == '1');
            /**
                假若把它变成111...000这种形式
                那么对于左部分是0的部分,要对它进行翻转(也就是对它进行操作),
                还要再加上右部分是1的个数
                这部分就是total1 - nr1,nr1此时扮演左半部分为1的个数,总的1的个数减去它,
                就是右半部分为1的个数。

            */
            ans = min(ans, nr0 + total1 - nr1);
            /**
            倘若把它变成000...111这种形式,思路和上面相似
            */

            ans = min(ans, nr1 + total0 - nr0);
        }
        cout << ans << endl;


    }
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-06-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档