[ 9.28 ]CF每日一题系列—— 940A规律构造

Description:

  输入a,b,x,给你a个0,b个1,你要给出一个组合,让这个组合里存在x位,使得这x为和其x+1位不相等

Solution:
  因为肯定有一个正确的答案,所以钻了一下空子,贪心,让个数多的在前,然后0101这样添加,知道最后一个需要满足的x,因为我这么贪心可定是能找到一个满足的,所以对于最后一个必然存在一个0/1和当前的倒数第一位不同,所以觜最后连续填充0/1,的到最后一个满足的x

Code:

  

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;

int main()
{
    int a,b,x;
    while(~scanf("%d%d%d",&a,&b,&x))
    {
        swap(a,b);
        int usenum = 1;
        if(a < b)usenum = 0;
        printf("%d",usenum);
        if(usenum == 0)b--;
        else a--;
        int out = usenum;
        for(int i = 1;i < x;++i)
        {
            out = i & 1 == 1 ? usenum^1 : usenum;
            if(out == 1)a--;
            else b--;
            printf("%d",out);
        }
        if(out == 1)
        {
            while(a)
            {
                printf("1");
                a--;
            }
            while(b)
            {
                printf("0");
                b--;
            }
        }
        else
        {
            while(b)
            {
                printf("0");
                b--;
            }
            while(a)
            {
                printf("1");
                a--;
            }
        }
        printf("\n");
    }
    return 0;
}

 

posted @ 2018-09-28 19:20  Butterflier  阅读(219)  评论(0编辑  收藏  举报