埃及分数
Last updated
Last updated
def EgyptianFraction(numerator, denominator):
result = []
if denominator % numerator == 0:
result.append(denominator // numerator)
elif numerator < denominator:
# 计算出最大单元分数
unit = denominator // numerator + 1
result.append(unit)
# 求出余下部分的单元分数 a/b - 1/c = (a*c-1) / (b*c)
remain = EgyptianFraction(numerator * unit - denominator,denominator * unit)
result.extend(remain)
# 不考虑其他情况
return resultvector<int> EgyptianFraction( unsigned int numerator, unsigned int denominator )
{
vector<int> ret;
vector<int> remain;
int unit;
if ( denominator % numerator == 0) // eg. 2/6
{
ret.push_back( denominator / numerator );
return ret;
}
else if ( numerator < denominator )
{
unit = denominator / numerator + 1;
ret.push_back( unit );
remain = EgyptianFraction( numerator*unit - denominator, denominator*unit );
}
ret.insert( end( ret ), begin( remain ), end( remain ) );
return ret;
}