#include <bits/stdc++.h>
using namespace std;

long long modpow(long long a,long long b,long long m) {
    long long ans = 1;
    while(b) {
        if(b & 1) {
            (ans *= a) %= m;
        }
        (a *= a) %= m;
        b /= 2;
    }
    return ans;
}

int main() {
    long long n,m;
    cin >> n >> m;
    vector<int>a(n),b(m);
    int x = 0;
    for(int i = 0; i < n; i++) {
        cin >> a[i];
        x ^= a[i];
    }
    for(int i = 0; i < m; i++) {
        cin >> b[i];
        x ^= b[i];
    }
    cout << ((x == 0)?modpow(1 << 20,(n-1)*(m-1),998244353):0) << endl;
}