数据结构【线性表(二)链表】项目之线性表的应用:表的自然连接

/*
  *数据结构【线性表(二)链表】项目之线性表的应用:表的自然连接
  *Copyright (c) 2015 烟台大学计算机与控制工程学院
  *All right reserved.
  *文件名称:danlianbiao.cpp
  *标题:数据结构【线性表(二)链表】项目之单链表:逆置、连接与递增判断
  *分类:单链表:逆置、连接与递增判断
  *writer:罗海员
  *date:2015年10月04日
  *版本:V1.0.1
  *操作系统:XP
  *运行环境:VC6.0
  *问题描述:有表A,m1行、n1列,表B,m2行、n2列,求A和B的自然连接结果C (图如下)
  *提示:
        1. 定义单链表存储结构,用头插法和尾插法建立单链表,并显示建立好以后的结果。
        2.复杂度的要求,设计算法并用专门的函数实现算法;
        3.理论与实践相结合

*/



<span style="font-size:14px;">#include <stdio.h>
#include <malloc.h>
#define MaxCol  10          //最大列数
typedef int ElemType;
typedef struct Node1        //定义数据结点类型
{
    ElemType data[MaxCol];
    struct Node1 *next;     //指向后继数据结点
} DList;
typedef struct Node2        //定义头结点类型
{
    int Row,Col;            //行数和列数
    DList *next;            //指向第一个数据结点
} HList;
void CreateTable(HList *&h)
{
    int i,j;
    DList *r,*s;
    h=(HList *)malloc(sizeof(HList));       //创建头结点
    h->next=NULL;
    printf("表的行数,列数:");
    scanf("%d%d",&h->Row,&h->Col);
    for (i=0; i<h->Row; i++)
    {
        printf("  第%d行:",i+1);
        s=(DList *)malloc(sizeof(DList));   //创建数据结点
        for (j=0; j<h->Col; j++)                //输入一行的数据初步统计
            scanf("%d",&s->data[j]);
        if (h->next==NULL)                  //插入第一个数据结点
            h->next=s;
        else                                //插入其他数据结点
            r->next=s;                      //将*s插入到*r结点之后
        r=s;                                //r始终指向最后一个数据结点
    }
    r->next=NULL;                           //表尾结点next域置空
}
void DispTable(HList *h)
{
    int j;
    DList *p=h->next;
    while (p!=NULL)
    {
        for (j=0; j<h->Col; j++)
            printf("%4d",p->data[j]);
        printf("\n");
        p=p->next;
    }
}
void LinkTable(HList *h1,HList *h2,HList *&h)
{
    int f1,f2,i;
    DList *p=h1->next,*q,*s,*r;
    printf("连接字段是:第1个表位序,第2个表位序:");
    scanf("%d%d",&f1,&f2);
    h=(HList *)malloc(sizeof(HList));
    h->Row=0;
    h->Col=h1->Col+h2->Col;
    h->next=NULL;
    while (p!=NULL)
    {
        q=h2->next;
        while (q!=NULL)
        {
            if (p->data[f1-1]==q->data[f2-1])       //对应字段值相等
            {
                s=(DList *)malloc(sizeof(DList));   //创建一个数据结点
                for (i=0; i<h1->Col; i++)               //复制表1的当前行
                    s->data[i]=p->data[i];
                for (i=0; i<h2->Col; i++)
                    s->data[h1->Col+i]=q->data[i];  //复制表2的当前行
                if (h->next==NULL)              //插入第一个数据结点
                    h->next=s;
                else                            //插入其他数据结点
                    r->next=s;
                r=s;                            //r始终指向最后数据结点
                h->Row++;                       //表行数增1
            }
            q=q->next;                          //表2下移一个记录
        }
        p=p->next;                              //表1下移一个记录
    }
    r->next=NULL;                               //表尾结点next域置空
}
int main()
{
    HList *h1,*h2,*h;
    printf("表1:\n");
    CreateTable(h1);            //创建表1
    printf("表2:\n");
    CreateTable(h2);            //创建表2
    LinkTable(h1,h2,h);         //连接两个表
    printf("连接结果表:\n");
    DispTable(h);               //输出连接结果
    return 0;
}</span>


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值