#P4497. Addition Chains

Addition Chains

题目描述

已知一个数列 a0,a1ama_0,a_1 \dots a_m(其中 $a_0 = 1,\ a_m = n,\ a_0 \lt a_1 \lt a_2 \lt ... \lt a_{m-1} \lt a_m$)。对于每个 kk,需要满足 ak=ai+aja_k=a_i+a_j0i, jk10 \leq i,\ j \leq k-1,这里 iijj 可以相等)。

现给定 nn 的值,要求 mm 的最小值(并不要求输出),及这个数列每一项的值(可能存在多个数列,只输出任一个满足条件的就可以了)。

输入格式

多组数据,每行给定一个正整数 nn

输入以 00 结束。

输出格式

对于每组数据,输出满足条件的长度最小的数列。

5
7
12
15
77
0
1 2 4 5
1 2 4 6 7
1 2 4 8 12
1 2 4 5 10 15
1 2 4 8 9 17 34 68 77

提示

1n100, 1km1 \leq n \leq 100,\ 1 \leq k \leq m