#T1443. 「一本通 1.3 例 4」Addition Chains

「一本通 1.3 例 4」Addition Chains

题目描述

已知一个数列a_0,a_1a_ma\_0, a\_1 ……a\_m,其中a_0=1,a_m=na\_0=1,a\_m=n; a_0<a_1<a_2<<a_m1<a_ma\_0 < a\_1 < a\_2 < …… < a\_{m-1} < a\_m。对于每个k(1km)k(1≤k≤m)满足a_k=a_i+a_j(0i,jk1)a\_k=a\_i+a\_j(0≤i,j≤k-1),这里iijj可以相等。

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

输入

多组数据,每行给定一个正整数nn。输入以0结束。

输出

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

样例

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

来源

一本通在线评测