C. Increase and Copy
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Initially, you have the array $a$ consisting of one element $1$ ($a = [1]$).

In one move, you can do one of the following things:

• Increase some (single) element of $a$ by $1$ (choose some $i$ from $1$ to the current length of $a$ and increase $a_i$ by one);
• Append the copy of some (single) element of $a$ to the end of the array (choose some $i$ from $1$ to the current length of $a$ and append $a_i$ to the end of the array).

For example, consider the sequence of five moves:

1. You take the first element $a_1$, append its copy to the end of the array and get $a = [1, 1]$.
2. You take the first element $a_1$, increase it by $1$ and get $a = [2, 1]$.
3. You take the second element $a_2$, append its copy to the end of the array and get $a = [2, 1, 1]$.
4. You take the first element $a_1$, append its copy to the end of the array and get $a = [2, 1, 1, 2]$.
5. You take the fourth element $a_4$, increase it by $1$ and get $a = [2, 1, 1, 3]$.

Your task is to find the minimum number of moves required to obtain the array with the sum at least $n$.

You have to answer $t$ independent test cases.

Input

The first line of the input contains one integer $t$ ($1 \le t \le 1000$) — the number of test cases. Then $t$ test cases follow.

The only line of the test case contains one integer $n$ ($1 \le n \le 10^9$) — the lower bound on the sum of the array.

Output

For each test case, print the answer: the minimum number of moves required to obtain the array with the sum at least $n$.

Example
Input
5
1
5
42
1337
1000000000

Output
0
3
11
72
63244