#include <cstdio>
#include <cstring>
#include <algorithm>
int Max[550000], cMax[550000]; 
int n, a[550000], Ans[550000];
int o[4];
int main()
{
	scanf("%d", &n);
	for(int i = 0; i < (1 << n); i++) scanf("%d", &a[i]);
	memset(Max, -1, sizeof(Max));
	memset(cMax, -1, sizeof(cMax));
	Max[0] = a[0];
	if(a[1] > a[0]) Max[1] = a[1], cMax[1] = a[0];
	else Max[1] = a[0], cMax[1] = a[1];
	Ans[1] = a[0] + a[1];
	printf("%d\n", a[0] + a[1]);
	for(int i = 2; i < (1 << n); i++)
	{
		int S = 0, b;
		for(int j = 17; j >= 0; j--)
		{
			if((i >> j) & 1)
			{
				S = i ^ (1 << j);
				b = j;
				break;
			}
		}
		b = 1 << b;
		for(int j = S; ; j = ((j - 1) & S))
		{
			int u = a[b ^ j];
			if(u > Max[i]) cMax[i] = Max[i], Max[i] = u;
			else if(u > cMax[i]) cMax[i] = u;
			if(j == 0) break;
		}
		o[0] = Max[i]; o[1] = cMax[i]; o[2] = Max[S]; o[3] = cMax[S];
		std::sort(o, o + 4);
		Max[i] = o[3]; cMax[i] = o[2];
		if(cMax[i] == -1)
		{
			Ans[i] = Ans[i - 1];
			printf("%d\n", Ans[i]);
		}
		else
		{
			Ans[i] = std::max(Max[i] + cMax[i], Ans[i - 1]);
			printf("%d\n", Ans[i]);
		}
	}
	return 0;
}