Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

D. Third Month Insanity

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputThe annual college sports-ball tournament is approaching, which for trademark reasons we'll refer to as Third Month Insanity. There are a total of 2^{N} teams participating in the tournament, numbered from 1 to 2^{N}. The tournament lasts *N* rounds, with each round eliminating half the teams. The first round consists of 2^{N - 1} games, numbered starting from 1. In game *i*, team 2·*i* - 1 will play against team 2·*i*. The loser is eliminated and the winner advances to the next round (there are no ties). Each subsequent round has half as many games as the previous round, and in game *i* the winner of the previous round's game 2·*i* - 1 will play against the winner of the previous round's game 2·*i*.

Every year the office has a pool to see who can create the best bracket. A bracket is a set of winner predictions for every game. For games in the first round you may predict either team to win, but for games in later rounds the winner you predict must also be predicted as a winner in the previous round. Note that the bracket is fully constructed before any games are actually played. Correct predictions in the first round are worth 1 point, and correct predictions in each subsequent round are worth twice as many points as the previous, so correct predictions in the final game are worth 2^{N - 1} points.

For every pair of teams in the league, you have estimated the probability of each team winning if they play against each other. Now you want to construct a bracket with the maximum possible expected score.

Input

Input will begin with a line containing *N* (2 ≤ *N* ≤ 6).

2^{N} lines follow, each with 2^{N} integers. The *j*-th column of the *i*-th row indicates the percentage chance that team *i* will defeat team *j*, unless *i* = *j*, in which case the value will be 0. It is guaranteed that the *i*-th column of the *j*-th row plus the *j*-th column of the *i*-th row will add to exactly 100.

Output

Print the maximum possible expected score over all possible brackets. Your answer must be correct to within an absolute or relative error of 10^{ - 9}.

Formally, let your answer be *a*, and the jury's answer be *b*. Your answer will be considered correct, if .

Examples

Input

2

0 40 100 100

60 0 40 40

0 60 0 45

0 60 55 0

Output

1.75

Input

3

0 0 100 0 100 0 0 0

100 0 100 0 0 0 100 100

0 0 0 100 100 0 0 0

100 100 0 0 0 0 100 100

0 100 0 100 0 0 100 0

100 100 100 100 100 0 0 0

100 0 100 0 0 100 0 0

100 0 100 0 100 100 100 0

Output

12

Input

2

0 21 41 26

79 0 97 33

59 3 0 91

74 67 9 0

Output

3.141592

Note

In the first example, you should predict teams 1 and 4 to win in round 1, and team 1 to win in round 2. Recall that the winner you predict in round 2 must also be predicted as a winner in round 1.

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Jun/19/2019 03:00:11 (f2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|