#define _USE_MATH_DEFINES
#pragma region include
#include <iomanip>
#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <cmath>
#include <complex>
#include <iterator>
#include <sstream>
#include <bitset>
#include <cstring>
#include <string>
#include <vector>
#include <list>
#include <map>
#include <queue>
#include <set>
#include <stack>
#include <ctime>
#pragma endregion 
#pragma region typedef
typedef long long LL;
typedef long double LD;
typedef unsigned long long ULL;
#pragma endregion 
const int INF = (int)1e9;
const LL MOD = (LL)1e9 + 7;
const LL LINF = (LL)4e18 + 20;
const LD PI = acos(-1.0);
const double EPS = 1e-9;
using namespace ::std;
void solve() {
  int N, K;
  cin >> N >> K;
  vector<int> A(N);
  for (int i = 0; i < N; ++i) {
    cin >> A[i];
  }
  vector<vector<LL>> fld(N + 1, vector<LL>(256, 0));
  fld[0][0] = 1; 
  for (int i = 0; i < N; ++i) {
    for (int num = i; num >= 0; --num) {
      for (int val = 255; val >= 0; --val) {
        if (fld[num][val]) {
          fld[num + 1][val ^ A[i]] += fld[num][val];
          if (fld[num + 1][val ^ A[i]] >= MOD) {
            fld[num + 1][val ^ A[i]] -= MOD;
          }
        }
      }
    }
  }
  LL ans = fld[0][K];
  LL mul = 1;
  for (LL i = 1; i <= N; ++i) {
    ans = ans + (fld[(int)i][K] * mul) % MOD;
    ans %= MOD;
    mul = (mul * (i + 1)) % MOD;
  }
  cout << ans << endl;
}
#pragma region main
signed main(void) {
  std::cin.tie(0);
  std::ios::sync_with_stdio(false);
  std::cout << std::fixed; 
  cout << setprecision(16); 
  solve();
}
#pragma endregion 
