Time Limit: 10 second

Memory Limit: 2 MB

问题描述

     对任意给定的一个自然数n(n<=100),将分母小于等于n的不可约的真分数按上升的次序排序,并且在第一个分数前加上0/1,而在最后一个分数后加上1/1,这个序列称为n阶法雷序列,以Fn表示。例如,F8为:

     0/1、1/8、1/7、1/6、1/5、1/4、2/7、1/3、3/8、2/5、3/7、1/2、4/7、3/5、5/8、2/3、5/7、3/4、4/5、5/6、6/7、7/8、1/1。


    编程求出n阶法雷序列,每行输出10个分数。

Input

输入为一个正整数n

Output

输出若干行,每行10个分式。(每个分式用空格隔开,为简化输出,每行的最后一个分式后也有一个空格,最后用换行结束)

Sample Input

    8

Sample Output

0/1 1/8 1/7 1/6 1/5 1/4 2/7 1/3 3/8 2/5
3/7 1/2 4/7 3/5 5/8 2/3 5/7 3/4 4/5 5/6
6/7 7/8 1/1
 

【题解】

真分数可以根据两个数是否互质来判断,或者换个说法,两个数的最大公因数是否为1,如果为1就互质。然后用一个结构来存储 分数的分子和分母,这里同时还要存储这个分数的小数形式。因为我们要根据小数来排序。在排序的时候,把整个结构都交换。在排序之前再加入一个0/1 1/1到数组里就好。两个数互质就加入这个结构数组。

【代码】

#include <cstdio>

struct fln

{
int fs[2];
double xs;
}; int n,num = 0;
fln bb[20000]; int gcd(int a,int b) //获取两个数的最大公因数
{
if (b == 0)
return a;
else
return gcd(b,a % b); } void input_data()
{
scanf("%d",&n);
} void get_ans()
{
for (int i = 1;i <= n;i++)
for (int j = i+1;j <= n;j++) //获取i和j 即i/j ,其中i < j,且i,j互质
if (gcd(i,j) == 1)
{
num++;
bb[num].fs[0] = i; //fs代表分数
bb[num].fs[1] = j;
double aa = (double) i;
double cc = (double) j;
double temp = aa / cc;
bb[num].xs = temp; //记录小数
}
bb[++num].fs[0] = 0; //把 0/1 和 1/1加入数组中.
bb[num].fs[1] = 1;
bb[num].xs =0.0;
bb[++num].fs[0] = 1;
bb[num].fs[1] = 1;
bb[num].xs = 1.0;
} void kp(int l,int r) //以小数作为元素 进行快排。
{
int i = l,j = r;double m = bb[(i+j)/2].xs;
do
{
while (bb[i].xs < m) i++;
while (m < bb[j].xs) j--;
if (i <= j)
{
int m; //要整个交换 这一段可以写成 fln m m = bb[i];bb[i] = bb[j];bb[j] = m,这样会短很多.
m = bb[i].fs[0];bb[i].fs[0] = bb[j].fs[0];bb[j].fs[0] = m;
m = bb[i].fs[1];bb[i].fs[1] = bb[j].fs[1];bb[j].fs[1] = m;
double tt;
tt = bb[i].xs;bb[i].xs = bb[j].xs;bb[j].xs = tt;
i++;j--;
}
}
while (i <= j);
if (l < j) kp(l,j);
if (i < r) kp (i,r);
} void output_ans()
{
int m = 0;
for (int i = 1;i <= num;i++) //控制一下输出
{
printf("%d/%d ",bb[i].fs[0],bb[i].fs[1]);
m++;
if (m == 10)
{
printf("\n");
m = 0;
}
}
} int main()
{
input_data();
get_ans();
kp(1,num);
output_ans();
return 0;
}

【7001】n阶法雷序列的更多相关文章

  1. 【USACO 2.1.2】法雷序列

    [问题描述]     对任意给定的一个自然数 n(n<=160), 将分母小于等于 n 的不可约的真分数按上升的次序排序 , 并且在第一个分数前加上 0/1, 而在最后一个分数后加上 1/1, ...

  2. 5阶m序列

    void echo32(int m) { printf("%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d\n ...

  3. 小数化分数的O(log2n)解法

    具体约束: 给定一个小数x,x满足0<=x<1,且保证给定的x保留了18位小数 输出一个分数,使得分母不超过1e9,分子分母互质,且在满足这些条件的情况下最接近x 了解一下法雷数列和ste ...

  4. 数字信号处理MATLAB简单序列

    数字信号处理应用的几个基本序列: 1 单位样本序列 function mainImseq() clc clear disp('生成抽样序列'); y=imseq(,,); %调用样本函数,此时序列下标 ...

  5. m序列

    产生m序列移位寄存器是一种逻辑电路,1阶,2阶...的电路图各不相同. 一般使用本原多项式计算出各阶数电路图. 一般的多项式为 f(x) = c0 * x^0 + c1 * x^1 + c2 * x^ ...

  6. 在matlab中生成m序列

    实验环境为matlab2013b 1.首先编写一个mseq.m文件,内容为: function[mseq]=m_sequence(fbconnection)  n=length(fbconnectio ...

  7. 【经典面试题】实现平方根函数sqrt

    本文将从一道经典的面试题说起:实现平方根函数,不得调用其它库函数. 函数原型声明例如以下: double Sqrt(double A); 二分法 二分法的概念 求,等价于求方程的非负根(解).求解方程 ...

  8. XVIII Open Cup named after E.V. Pankratiev. Grand Prix of SPb

    A. Base $i - 1$ Notation 两个性质: $2=1100$ $122=0$ 利用这两条性质实现高精度加法即可. 时间复杂度$O(n)$. #include<stdio.h&g ...

  9. hdu-1121(差分法--数学问题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1121 参考文章:https://blog.csdn.net/fengzhizi76506/articl ...

随机推荐

  1. POJ 1474 Video Surveillance 半平面交/多边形核是否存在

    http://poj.org/problem?id=1474 解法同POJ 1279 A一送一 缺点是还是O(n^2) ...nlogn的过几天补上... /********************* ...

  2. python2 python3 m2crypto 安装(rsa 私钥文件加密)

    转自作者:大道至简_Andy 原文链接:https://www.jianshu.com/p/b308357ef649 第一种方式:使用apt-get(以Python2版本进行测试的) sudo apt ...

  3. 一个简单RPC框架是怎样炼成的(II)——制定RPC消息

    开局篇我们说了,RPC框架的四个核心内容 RPC数据的传输. RPC消息 协议 RPC服务注冊 RPC消息处理 以下,我们先看一个普通的过程调用 class Client(object): def _ ...

  4. vue.js最最最最简单实例

    vue.js最最最最简单实例 一.总结 一句话总结: 1.vue.js实现实现数据的双向绑定用的是什么标记? 双大括号:比如{{message}} 2.vue数据循环输出的标记是什么? 用的是标签的v ...

  5. 非常不错的canvas效果,线随心动

    非常不错的canvas效果,下面是html代码. <!DOCTYPE html> <html> <head> <meta charset="utf- ...

  6. 【问题】VUE 同一页面路由参数变化,数据不刷新

    依赖路由的params参数获取写在created生命周期里面,因为相同路由二次甚至多次加载的关系 没有达到监听,退出页面再进入另一个页面并不会运行created组件生命周期,导致数据还是第一次进入的数 ...

  7. slice深拷贝数组

    var a = [1, 2, 3, 4] var b = a.slice(0) b[0] = 2 // a = [1, 2, 3, 4] // b = [2, 2, 3, 4]

  8. BZOJ2243: [SDOI2011]染色(树链剖分/LCT)

    Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认为是同一段), 如 ...

  9. php中 重载(二)

    接着上一次说的重载,我们了解下php中的重载,方法的重载,假设有管重载定义,參考:php中 重载(一)这个文章,谢谢.作为刚開始学习的人,大牛勿喷: 基本是两个方法 __call,当调用对一个不可訪问 ...

  10. Android学习笔记之网络接口(Http接口,Apache接口,Android接口)

    目前Android平台有三种网络接口可以使用,他们分别是:Java.NET.*(标准Java接口),org.apache(Apache接口),和android.Net.*(android网络接口). ...