CF BUDDY
← Problems·

1922E · Increasing Subsequences

1800 · bitmasks, constructive algorithms, divide and conquer

Problem: Let's recall that an increasing subsequence of the array aa is a sequence that can be obtained from it by removing some elements without changing the order of the remaining elements, and the remaining elements are strictly increasing (i. e ab1<ab2<<abka_{b_1} < a_{b_2} < \dots < a_{b_k} and b1<b2<<bkb_1 < b_2 < \dots < b_k). Note that an empty subsequence is also increasing.

You are given a positive integer XX. Your task is to find an array of integers of length at most 200200, such that it has exactly XX increasing subsequences, or report that there is no such array. If there are several answers, you can print any of them.

If two subsequences consist of the same elements, but correspond to different positions in the array, they are considered different (for example, the array [2,2][2, 2] has two different subsequences equal to [2][2]).

Input Format: The first line contains a single integer tt (1t10001 \le t \le 1000) — the number of test cases.

The only line of each test case contains a single integer XX (2X10182 \le X \le 10^{18}).

Output Format: For each query, print the answer to it. If it is impossible to find the required array, print -1 on the first line. Otherwise, print a positive integer nn on the first line — the length of the array. On the second line, print nn integers — the required array itself. If there are several answers, you can print any of them. All elements of the array should be in the range [109;109][-10^9; 10^9].

Sample Cases

Case 1

Input

4
2
5
13
37

Output

1
0
3
0 1 0
5
2 2 3 4 2
7
-1 -1 0 0 2 3 -1

Similar problems

00:00:00
Loading editor…
Welcome! I'm your coding tutor for this problem. Use the chips below to reveal stored hints or get AI feedback on your code. I'll guide you step by step — never giving away the solution.

Sign in to unlock AI tutor feedback