Parity Game

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.

Examples

input

01011
0110

output

YES

input

0011
1110

output

NO

Note

In the first sample, the steps are as follows: 01011 → 1011 → 011 → 0110

Solution:

#include <iostream>
#include <iomanip>
#include <stdio.h>
#include <set>
#include <vector>
#include <map>
#include <cmath>
#include <algorithm>
#include <memory.h>
#include <string>
#include <sstream>

using namespace std;

int main() {
string a, b;
cin >> a >> b;
int n = a.length(), m = b.length();
int x = 0, y = 0;
for (int i=0;i<n;i++)
    if (a[i] == '1') x++;
  for (int i=0;i<m;i++)
    if (b[i] == '1') y++;
  if (x & 1) x++;
  if (x >= y) cout << "YES" << endl;
  else cout << "NO" << endl;
  return 0;
}