UVa Problem 10077 The Stern-Brocot Number System (Stern-Brocot 代数系统)

本文介绍了一种用于求解Stern-Brocot数系中特定分数路径的算法实现。通过不断逼近目标分数,算法可以高效地确定从根节点到目标分数的路径方向。
// The Stern-Brocot Number System (Stern-Brocot 代数系统) // PC/UVa IDs: 110507/10077, Popularity: C, Success rate: high Level: 1 // Verdict: Accepted // Submission Date: 2011-05-29 // UVa Run Time: 0.016s // // 版权所有(C)2011,邱秋。metaphysis # yeah dot net // // 直接根据题意,定义3个分数,根据要求的分数与中间分数比较大小决定向左还是向右。 #include <iostream> using namespace std; struct fraction { long long unsigned numerator; long long unsigned denominator; }; int main(int ac, char *av[]) { long long unsigned up, down; fraction left, right, middle; while (cin >> up >> down, (up - down)) { left.numerator = 0; left.denominator = 1; right.numerator = 1; right.denominator = 0; middle.numerator = 1; middle.denominator = 1; while (1) { if (up * middle.denominator == down * middle.numerator) break; if (up * middle.denominator > down * middle.numerator) { cout << "R"; left.numerator = middle.numerator; left.denominator = middle.denominator; middle.numerator = (left.numerator + right.numerator); middle.denominator = (left.denominator + right.denominator); } else { cout << "L"; right.numerator = middle.numerator; right.denominator = middle.denominator; middle.numerator = (left.numerator + right.numerator); middle.denominator = (left.denominator + right.denominator); } } cout << endl; } return 0; }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值