数据结构实验之链表八:Farey序列

简介: 数据结构实验之链表八:Farey序列

数据结构实验之链表八:Farey序列

Time Limit: 10 ms Memory Limit: 600 KiB

SubmitStatistic

Problem Description

Farey序列是一个这样的序列:其第一级序列定义为(0/1,1/1),这一序列扩展到第二级形成序列(0/1,1/2,1/1),扩展到第三极形成序列(0/1,1/3,1/2,2/3,1/1),扩展到第四级则形成序列(0/1,1/4,1/3,1/2,2/3,3/4,1/1)。以后在每一级n,如果上一级的任何两个相邻分数a/c与b/d满足(c+d)<=n,就将一个新的分数(a+b)/(c+d)插入在两个分数之间。对于给定的n值,依次输出其第n级序列所包含的每一个分数。

Input

输入一个整数n(0<n<=100)

Output

依次输出第n级序列所包含的每一个分数,每行输出10个分数,同一行的两个相邻分数间隔一个制表符的距离。

Sample Input

6

Sample Output

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

4/5   5/6   1/1

Hint

 

Source

#include<stdio.h>
#include<stdlib.h>
struct hh
{
    int a;
    int b;
    struct hh *next;
};
int main()
{
    int n,k;
    struct hh *head,*p,*t,*p1,*p2;
    scanf("%d",&n);
    head=(struct hh *)malloc(sizeof(struct hh));
    head->next=NULL;
    t=head;
    p=(struct hh *)malloc(sizeof(struct hh));
    p->a=0;
    p->b=1;
    p->next=t->next;
    t->next=p;
    t=p;
    p=(struct hh *)malloc(sizeof(struct hh));
    p->a=1;
    p->b=1;
    p->next=t->next;
    t->next=p;
    t=p;
    k=1;
    while(k==1)
    {
        p1=head->next;
        p2=p1->next;
        p=NULL;
        while(p2!=NULL)
        {
            if((p1->b+p2->b)<=n)
            {
                p=(struct hh *)malloc(sizeof(struct hh));
                p->a=p1->a+p2->a;
                p->b=p1->b+p2->b;
                p->next=p1->next;
                p1->next=p;
            }
            p1=p2;
            p2=p2->next;
        }
        if(p==NULL)
            k=0;
    }
    k=0;
    p=head->next;
    while(p!=NULL)
    {
        k++;
        if(k<10)
            printf("%d/%d\t",p->a,p->b);
        else if(k==10)
        {
            printf("%d/%d\n",p->a,p->b);
            k=0;
        }
        p=p->next;
    }
    return 0;
}


相关文章
|
20天前
|
存储 C语言
【数据结构】手把手教你单链表(c语言)(附源码)
本文介绍了单链表的基本概念、结构定义及其实现方法。单链表是一种内存地址不连续但逻辑顺序连续的数据结构,每个节点包含数据域和指针域。文章详细讲解了单链表的常见操作,如头插、尾插、头删、尾删、查找、指定位置插入和删除等,并提供了完整的C语言代码示例。通过学习单链表,可以更好地理解数据结构的底层逻辑,提高编程能力。
48 4
|
22天前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
22天前
|
存储 Web App开发 算法
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法
|
1月前
|
存储 Java
数据结构第三篇【链表的相关知识点一及在线OJ习题】
数据结构第三篇【链表的相关知识点一及在线OJ习题】
26 7
|
1月前
|
算法 Java
数据结构与算法学习五:双链表的增、删、改、查
双链表的增、删、改、查操作及其Java实现,并通过实例演示了双向链表的优势和应用。
17 0
数据结构与算法学习五:双链表的增、删、改、查
|
20天前
|
C语言
【数据结构】双向带头循环链表(c语言)(附源码)
本文介绍了双向带头循环链表的概念和实现。双向带头循环链表具有三个关键点:双向、带头和循环。与单链表相比,它的头插、尾插、头删、尾删等操作的时间复杂度均为O(1),提高了运行效率。文章详细讲解了链表的结构定义、方法声明和实现,包括创建新节点、初始化、打印、判断是否为空、插入和删除节点等操作。最后提供了完整的代码示例。
39 0
|
1月前
|
存储
[数据结构] -- 双向循环链表
[数据结构] -- 双向循环链表
23 0
|
1月前
|
存储
探索数据结构:便捷的双向链表
探索数据结构:便捷的双向链表
|
1月前
|
存储
探索数据结构:单链表的实践和应用
探索数据结构:单链表的实践和应用
|
1月前
|
算法 Java
数据结构与算法学习六:单向环形链表应用实例的约瑟夫环问题
这篇文章通过单向环形链表的应用实例,详细讲解了约瑟夫环问题的解决方案,并提供了Java代码实现。
21 0

热门文章

最新文章

下一篇
无影云桌面