Algorithm


D. Vasya And The Matrix
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

Now Vasya is taking an exam in mathematics. In order to get a good mark, Vasya needs to guess the matrix that the teacher has constructed!

Vasya knows that the matrix consists of n rows and m columns. For each row, he knows the xor (bitwise excluding or) of the elements in this row. The sequence a1, a2, ..., an denotes the xor of elements in rows with indices 12, ..., n, respectively. Similarly, for each column, he knows the xor of the elements in this column. The sequence b1, b2, ..., bm denotes the xor of elements in columns with indices 12, ..., m, respectively.

Help Vasya! Find a matrix satisfying the given constraints or tell him that there is no suitable matrix.

Input

The first line contains two numbers n and m (2 ≤ n, m ≤ 100) — the dimensions of the matrix.

The second line contains n numbers a1, a2, ..., an (0 ≤ ai ≤ 109), where ai is the xor of all elements in row i.

The third line contains m numbers b1, b2, ..., bm (0 ≤ bi ≤ 109), where bi is the xor of all elements in column i.

Output

If there is no matrix satisfying the given constraints in the first line, output "NO".

Otherwise, on the first line output "YES", and then n rows of m numbers in each ci1, ci2, ... , cim (0 ≤ cij ≤ 2·109) — the description of the matrix.

If there are several suitable matrices, it is allowed to print any of them.

Examples
input
Copy
2 3
2 9
5 3 13
output
Copy
YES
3 4 5
6 7 8
input
Copy
3 3
1 7 6
2 15 12
output
Copy
NO

 



 

Code Examples

#1 Code Example with C++ Programming

Code - C++ Programming


#include <bits/stdc++.h>

using namespace std;

int const N = 101;
int n, m, a[N], b[N];

int main() {
  int cur = 0;
  scanf("%d %d", &n, &m);
  for(int i = 0; i < n; ++i)
    scanf("%d", a + i), cur ^= a[i];
  for(int i = 0; i < m; ++i)
    scanf("%d", b + i), cur ^= b[i];

  if(cur != 0) {
    puts("NO");
    return 0;
  }

  puts("YES");

  for(int i = 1; i < m; ++i)
    cur ^= b[i];
  cur ^= a[0];

  printf("%d ", cur);
  for(int i = 1; i < m; ++i)
    printf("%d ", b[i]);
  puts("");

  for(int i = 1; i < n; ++i) {
    printf("%d ", a[i]);
    for(int j = 1; j < m; ++j)
      printf("0 ");
    puts("");
  }

  return 0;
}
Copy The Code & Try With Live Editor

Input

x
+
cmd
2 3
2 9
5 3 13

Output

x
+
cmd
YES
3 4 5
6 7 8
Advertisements

Demonstration


Codeforces Solution-Vasya And The Matrix-Solution in C, C++, Java, Python,Codeforces Solution

Previous
Codeforces solution 1080-B-B. Margarite and the best present codeforces solution
Next
CodeChef solution DETSCORE - Determine the Score CodeChef solution C,C+