24h購物| | PChome| 登入
2012-05-19 19:30:30| 人氣1,822| 回應0 | 上一篇 | 下一篇

[UVA][Tree] 11350 - Stern-Brocot Tree

推薦 0 收藏 0 轉貼0 訂閱站台

K - Stern-Brocot Tree

Time Limit: 1 sec
Memory Limit: 16MB

In number theory, the Stern-Brocot tree is a method of listing all non-negative rational numbers as well as a point representing infinity (here represented formally as 1/0).

The tree may be created by an iterative process. It is easiest to describe as a list. Beginning with the list {0/1, 1/0} representing 0 and infinity respectively, one places between any two fractions the mediant of the fractions (the mediant of a/c and b/d is (a + b)/(c + d)). The first few steps of this process yield:
{0/1, 1/0}
{0/1, 1/1, 1/0}
{0/1, 1/2, 1/1, 2/1, 1/0}
{0/1, 1/3, 1/2, 2/3, 1/1, 3/2, 2/1, 3/1, 1/0}

This process can be represented as a tree where each row corresponds to the new numbers added at each step.

From Wikipedia

The position of a fraction in the tree can be specified as a path consisting of L(left) an R(right) moves along the tree starting from the top (fraction 1/1). Your have to find a fraction by a given path.

INPUT:

The first line contains integer N (0 < N <= 10000), it is number of tests. On next N lines there is a path in the tree. Path is the string if maximum length of 90 characters consisting from characters 'L' or 'R'.

OUTPUT:

For each test case print line formatted like this: "a/b". Where "a" is numerator and "b" is denominator of the fraction.

SAMPLE INPUT:

3
RL
RLR
RRL

SAMPLE OUTPUT:

3/2
5/3
5/2



#include <stdio.h>

int main() {
int t;
char str[100];
scanf("%d ", &t);
while(t--) {
gets(str);
unsigned long long la = 0, lb = 1, ma = 1, mb = 1, ra = 1, rb = 0;
unsigned long long x = 1, y = 1, i;
for(i = 0; str[i]; i++) {
if(str[i] == 'L') {
x = la+ma, y = lb+mb;
ra = ma, rb = mb;
ma = x, mb = y;
} else {
x = ra+ma, y = rb+mb;
la = ma, lb = mb;
ma = x, mb = y;
}
}
printf("%llu/%llu\n", x, y);
}
return 0;
}

台長: Morris
人氣(1,822) | 回應(0)| 推薦 (0)| 收藏 (0)| 轉寄
全站分類: 不分類 | 個人分類: UVA |
此分類下一篇:[UVA] 10474 - Where is the Marble?
此分類上一篇:[UVA][zkw式ST] 11525 - Permutation

是 (若未登入"個人新聞台帳號"則看不到回覆唷!)
* 請輸入識別碼:
請輸入圖片中算式的結果(可能為0) 
(有*為必填)
TOP
詳全文