已知一个非纯集合B,构造一个纯集合A,使集合A只含有B中值各不相同的成员(数据结构)

博客介绍了如何从一个非纯集合B中构造一个纯集合A,确保集合A的所有元素值都不相同,专注于数据结构中的顺序表操作。文章详细阐述了使用顺序表的12个函数来实现这一过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include "SqListFunc.cpp"
void InputElement(SqList &L)
{
    int i,num;
    ElemType e;
    printf("num= ");
    scanf("%d",&num);
    printf("Elem= ");
    for(i=1;i<=num;i++)
    {
        scanf("%d",&e);
        ListInsert_Sq(L,i,e);
    }
}
void purse(SqList &La,SqList &Lb)
{
    int La_len=0,Lb_len,i;
    Lb_len=ListLength_Sq(Lb);
    ElemType e;
    for(i=1;i<=Lb_len;i++)
    {
        ListDelete_Sq(Lb,1,e);
        if(!LocateElem_Sq(La,e))
        {
            ListInsert_Sq(La,++La_len,e);
        }
    }

}
int main()
{
    SqList La,Lb;
    printf("*************************输入B*************************\n");
    InitList_Sq(Lb);
    InputElement(Lb);
    InitList_Sq(La);

    purse(La,Lb);
    printf("*************************输出A****************************");
    ListTraverse_Sq(La);
    DestroyList_Sq(La);
    DestroyList_Sq(Lb);
    return 0;
}

顺序表的12个操作函数SqListFunc


                
1.将两个递增的有序链表合并为一个递增的有序链表。要求结果链表仍使用原来两个链表的 存储空间,不另外占用其他的存储空间。表中不允许有重复的数据。 2.将两个递减的有序链表合并为一个递增的有序链表。要求结果链表仍使用原来两个链 表的存储空间,不另外占用其他的存储空间。表中允许有重复的数据。 3.已知两个链表A和B分别表示两个集合,其元素递增排列。请设计一个算法,用于求出A 与B的交集,并存放在A链表中。 4.已知两个链表A和B分别表示两个集合,其元素递增排列。请设计算法求出两个集合A 和B的差集(即仅由在A中出现而不在B中出现的元素所构成的集合),并以同样的形式存储, 同时返回该集合的元素个数。 5.设计算法将一个带头结点的单链表A分解为两个具有相同结构的链表B和C,其中B表 的结点为A表中值小于零的结点,而C表的结点为A表中值大于零的结点(链表A中的元素为 零整数,要求B、C表利用A表的结点)。 6.设计一个算法,通过一趟遍历确定长度为n的单链表中值最大的结点,返回该结点的数 据域。 7.设计一个算法,将链表中所有结点的链接方向“原地”逆转,即要求仅利用原表的存储空 间,换句话说,要求算法的空间复杂度为O(1)。 8.设计一个算法,删除递增有序链表中值大于mink且小于maxk(mink和maxk是给定的 两个参数,其值可以和表中的元素相同,也可以不同)的所有元素。 9.已知 p 指向双向循环链表中的一个结点,其结点结构为(data, prior, next),写出算法 Exchange(p),交换 p 所指向的结点及其前驱结点的顺序。 10.已知长度为n的线性表A采用顺序存储结构,请写一个时间复杂度为O(n)、空间复杂度 为O(1)的算法,该算法可删除线性表中所有值为item的数据元素。 都使用C++编写
最新发布
03-08
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值