• Codeforces Round #180 (Div. 2) C. Parity Game 数学


    C. Parity Game

    题目连接:

    http://www.codeforces.com/contest/298/problem/C

    Description

    You are fishing with polar bears Alice and Bob. While waiting for the fish to bite, the polar bears get bored. They come up with a game. First Alice and Bob each writes a 01-string (strings that only contain character "0" and "1") a and b. Then you try to turn a into b using two types of operations:

    Write parity(a) to the end of a. For example, .
    Remove the first character of a. For example, . You cannot perform this operation if a is empty.
    You can use as many operations as you want. The problem is, is it possible to turn a into b?

    The parity of a 01-string is 1 if there is an odd number of "1"s in the string, and 0 otherwise.

    Input

    The first line contains the string a and the second line contains the string b (1 ≤ |a|, |b| ≤ 1000). Both strings contain only the characters "0" and "1". Here |x| denotes the length of the string x.

    Output

    Print "YES" (without quotes) if it is possible to turn a into b, and "NO" (without quotes) otherwise.

    Sample Input

    01011

    0110

    Sample Output

    YES

    Hint

    题意

    给你两个01串

    然后你有两种操作,第一种操作是将第一个01串的第一个数擦去

    第二个操作是将第一个01串结尾加上一个数k,k是01串中1的个数%2.

    题解:

    因为你存在擦去第一个数,和添加功能

    很显然你可以构造出任何1的个数小于等于原1的个数+原1的个数%2的个数的字符串

    因此,判断第一个数能否构成第二个数,只需要看1的个数就好了

    代码

    #include<bits/stdc++.h>
    using namespace std;
    
    string a,b;
    int main()
    {
        cin>>a>>b;
        int sum1=0,sum2=0;
        for(int i=0;i<a.size();i++)
            if(a[i]=='1')sum1++;
        for(int i=0;i<b.size();i++)
            if(b[i]=='1')sum2++;
        sum1+=sum1%2;
        if(sum1>=sum2)cout<<"YES"<<endl;
        else cout<<"NO"<<endl;
    }
  • 相关阅读:
    Markdown常用写法
    Vue.js学习篇
    ClassLoader
    Java内存篇
    Spring-AOP学习篇
    M3U8Downloader
    IngCrawler
    ulimit开启coredump时核心转储
    Linux下的bc计算器
    Maven相关介绍
  • 原文地址:https://www.cnblogs.com/qscqesze/p/5116532.html
Copyright © 2020-2023  润新知