The biggest event of the year – Cota 2 world championship “The Innernational” is right around the corner. $2^n$ teams will compete in a double-elimination format (please, carefully read problem statement even if you know what is it) to identify the champion.

Teams are numbered from $1$ to $2^n$ and will play games one-on-one. All teams start in the upper bracket.

All upper bracket matches will be held played between teams that haven’t lost any games yet. Teams are split into games by team numbers. Game winner advances in the next round of upper bracket, losers drop into the lower bracket.

Lower bracket starts with $2^{n-1}$ teams that lost the first upper bracket game. Each lower bracket round consists of two games. In the first game of a round $2^k$ teams play a game with each other (teams are split into games by team numbers). $2^{k-1}$ loosing teams are eliminated from the championship, $2^{k-1}$ winning teams are playing $2^{k-1}$ teams that got eliminated in this round of upper bracket (again, teams are split into games by team numbers). As a result of each round both upper and lower bracket have $2^{k-1}$ teams remaining. See example notes for better understanding.

Single remaining team of upper bracket plays with single remaining team of lower bracket in grand-finals to identify championship winner.

You are a fan of teams with numbers $a_1, a_2, …, a_k$. You want the championship to have as many games with your favourite teams as possible. Luckily, you can affect results of every championship game the way you want. What’s maximal possible number of championship games that include teams you’re fan of?Input

First input line has two integers $n, k$ — $2^n$ teams are competing in the championship. You are a fan of $k$ teams ($2 \le n \le 17; 0 \le k \le 2^n$).

Second input line has $k$ distinct integers $a_1, \ldots, a_k$ — numbers of teams you’re a fan of ($1 \le a_i \le 2^n$).Output

Output single integer — maximal possible number of championship games that include teams you’re fan of.Examplesinput

3 1 6

output

6

input

3 3 1 7 8

output

11

input

3 4 1 3 5 7

output

14

Note

On the image, each game of the championship is denoted with an English letter ($a$ to $n$). Winner of game $i$ is denoted as $Wi$, loser is denoted as $Li$. Teams you’re a fan of are highlighted with red background.

In the first example, team $6$ will play in 6 games if it looses the first upper bracket game (game $c$) and wins all lower bracket games (games $h, j, l, m$).

In the second example, teams $7$ and $8$ have to play with each other in the first game of upper bracket (game $d$). Team $8$ can win all remaining games in upper bracket, when teams $1$ and $7$ will compete in the lower bracket.

In the third example, your favourite teams can play in all games of the championship.

**Solution:**

#include <bits/stdc++.h> using namespace std; int dp[20][1 << 17][2][2]; int main() { ios::sync_with_stdio(false); cin.tie(0); int n, m; cin >> n >> m; vector<int> fan(1 << n); for (int i = 0; i < m; i++) { int x; cin >> x; --x; fan[x] = 1; } memset(dp, 255, sizeof(dp)); for (int i = 0; i < (1 << n); i += 2) { dp[1][i][fan[i]][fan[i + 1]] = (fan[i] | fan[i + 1]); dp[1][i][fan[i + 1]][fan[i]] = (fan[i] | fan[i + 1]); } for (int j = 2; j <= n; j++) { for (int i = 0; i < (1 << n); i += (1 << j)) { int k = i + (1 << (j - 1)); for (int ui = 0; ui < 2; ui++) { for (int li = 0; li < 2; li++) { for (int uk = 0; uk < 2; uk++) { for (int lk = 0; lk < 2; lk++) { int fi = dp[j - 1][i][ui][li]; int fk = dp[j - 1][k][uk][lk]; if (fi >= 0 && fk >= 0) { int ft = fi + fk + (ui | uk) + (li | lk); for (int uw = 0; uw < 2; uw++) { for (int lw = 0; lw < 2; lw++) { for (int lw2 = 0; lw2 < 2; lw2++) { int new_u = (uw == 0 ? ui : uk); int new_l = (lw == 0 ? li : lk); int new_ft = ft + (new_l | (ui ^ uk ^ new_u)); int new_l2 = (lw2 == 0 ? new_l : (ui ^ uk ^ new_u)); dp[j][i][new_u][new_l2] = max(dp[j][i][new_u][new_l2], new_ft); } } } } } } } } } } int ans = 0; for (int ui = 0; ui < 2; ui++) { for (int li = 0; li < 2; li++) { ans = max(ans, dp[n][0][ui][li] + (ui | li)); } } cout << ans << '\n'; return 0; }