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 1, 2, ..., 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 1, 2, ..., 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
题意:给出n,m表示有一个n*m的矩阵,然后第一行给出n个数,每个数ai表示第i行所有的数的亦或和,第二行给出m个数,每个数bi表示第i列所有数的亦或和。问,是否可以构造出这样的一个矩阵,如果可以,输出“YES”并且输出这个矩阵,否则,输出“NO”.
思路:对于这样一个矩阵,我们只需要考虑最后一行和最后一列即可,其他都用0填充。然后,最后一行和最后一列也只需要考虑第n行第m个即可。对于样例 行:2 ,9 列:5,3,13 .我们只需要构造出
0,0, 2
5,3,15
这样一个矩阵即可,只需要考虑最后一个位置的数字即可,令最后一个数字为x的话,有
2^x=13, 5^3^x=9。很容易就可得出,x=13^2=9^5^3=15.
#include
using namespace std;
int main()
{
int x[105],y[105];
int n,m,xor1,xor2;
xor1=0,xor2=0;
cin>>n>>m;
for(int i=1;i<=n;i++){
cin>>x[i];
if(i!=n) xor1^=x[i];
}
for(int i=1;i<=m;i++){
cin>>y[i];
if(i!=m) xor2^=y[i];
}
xor2^=x[n];
xor1^=y[m];
if(xor1!=xor2){
cout<<"NO"<