埃及分数问题
时间限制:2000MS 内存限制:1000K
描述
所为埃及分数,是指分子为1的分数。任何一个分数都可以表示为埃及分数之和的形式。如:2/3=1/2+1/6,但不允许2/3=1/3+1/3,因为加数中有相同的。
对于一个分数a/b,表示方法有很多种,但是哪种最好呢?
首先,加数少的比加数多的好,其次,加数个数相同的,最小的分数越大越好。
如:
19/45=1/3 + 1/12 + 1/180
19/45=1/3 + 1/15 + 1/45
19/45=1/3 + 1/18 + 1/30
19/45=1/4 + 1/6 + 1/180
19/45=1/5 + 1/6 + 1/18.
最好的是最后一种,因为1/18比1/180,1/45,1/30,1/180都大。
对于给定的真分数,设计一个算法,找到用最好埃及分数表示真分数的表达式。
输入格式
仅一行,包括两个整数a和b,它们之间用空格分开,分别表示分数的分子和分母。
输出格式
用最好的埃及分数表示法来表示分数中的分母,从小到大依次输出。
输入样例
19 45
输出样例
5 6 18
Hint
按a/b可拆分成的单位分数的个数进行循环搜索。
1,如果a=1则直接输出。
2,否则从2个开始尝试。如果2个单位分数无法拼凑成a/b,则试3个……依此类推。那么我们搜索得到的第一个解一定会满足加数个数最少这个要求。
3,