#include using namespace std; #define REP(i,m,n) for(int i=(int)(m) ; i < (int) (n) ; ++i ) #define rep(i,n) REP(i,0,n) typedef long long ll; const ll mod=1e9+7 ; using B=bitset<350>; using mat = vector; int solve(mat a,int& rank) { int h = a.size(), w = a[0].size(); rep(j,w){ int pivot = -1; REP(i, rank, h) if(a[i][j]) {pivot = i; break;} if(pivot == -1) continue; swap(a[rank], a[pivot]); rep(i, h) if(i != rank && a[i][j]) a[i] ^= a[rank]; rank++; } return rank; } int main(){ int n,m; cin>>n>>m; int z; cin>>z; B x(z); mat a(n); rep(i,n){ int p; cin>>p; a[i]=p; } rep(i,m){ int type,l,r; cin>>type>>l>>r; --l; REP(j,l,r)a[j][i+30]=1; if(type)x[i+30]=1; } int rank1=0,rank2=0; solve(a,rank1); a.push_back(x); solve(a,rank2); if(rank1!=rank2){ cout<<0<