题目描述
2.1.2 Ordered Fractions顺序的分数
(frac1.pas/c/cpp)
输入一个自然数N,对于一个最简分数a/b(分子和分母互质的分数),满足1<=b<=N,0<=a/b<=1,请找出所有满足条件的分数。
这有一个例子,当N=5时,所有解为:
0/1 1/5 1/4 1/3 2/5 1/2 3/5 2/3 3/4 4/5 1/1
给定一个自然数N,1<=n<=160,请编程按分数值递增的顺序输出所有解。
注:①0和任意自然数的最大公约数就是那个自然数②互质指最大公约数等于1的两个自然数。格式
PROGRAM NAME: frac1
INPUT FORMAT:
(file frac1.in)
单独的一行 一个自然数N(1..160)
OUTPUT FORMAT:
(file frac1.out)
每个分数单独占一行,按照大小次序排列
SAMPLE INPUT
5
SAMPLE OUTPUT
0/1 1/5 1/4 1/3 2/5 1/2 3/5 2/3 3/4 4/5 1/1
解题思路:
因为数据不大,暴力解决
双重循环枚举分子和分母,然后对于每个分子分母,都跑一遍gcd
如果互素则压入vector中,最后排

该博客介绍了USACO中的Ordered Fractions问题,要求输出1到N间所有最简分数,按升序排列。作者提供了暴力求解的思路,通过双重循环检查分子和分母的互质性,并使用分数交叉相乘的积进行排序。代码实现包含在博客内容中。
最低0.47元/天 解锁文章
3550

被折叠的 条评论
为什么被折叠?



