鱼C论坛

 找回密码
 立即注册
查看: 1226|回复: 1

[已解决]线性表顺序存储

[复制链接]
发表于 2023-3-3 10:53:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
为什么顺序表里面的数字不是0~9而是0~8?

#include<stdio.h>
#include<stdlib.h>

typedef int ElemType;
typedef struct seqList
{
        int n;
        int maxLength;
        ElemType *element;
} SeqList;

#define ERROR 0
#define OK 1
#define Overflow 2                //Overflow 表示上溢 
#define Underflow 3        //Underflow 表示下溢
#define NotPresent 4        //Notpresent 表示元素不存在
#define Duplicate 5        //Duplicate 表示有重复元素
typedef int Status;
Status Init(SeqList *L,int mSize)
{
        L->maxLength = mSize;
        L->n = 0;
        L->element = (ElemType*)malloc(sizeof(ElemType)*mSize);                //动态生成一维数组空间
        if(!L->element)
                return ERROR;
        return OK;
}

Status Find(SeqList L,int i,ElemType *x)
{
        if(i<0||i>L.n-1)
                return ERROR;        //判断元素下标i是否越界
        *x = L.element[i];        //取出element[i]的值通过参数x返回
        return OK;
}

Status Insert(SeqList *L,int i,ElemType x)
{
        int j;
        if(i<-1||i>L->n-1)        //判断i下标是否越界
                return ERROR;
        if(L->n==L->maxLength)        // 判断顺序表存储空间是否已满
                return ERROR;
        for(j=L->n-1; j>i; j--)
                L->element[j+1]=L->element[j];        //从后往前逐个后移元素
        L->element[i+1]=x;        //将新元素放入下标为i+1的位置
        L->n=L->n+1;
        return OK;
}

Status Delete(SeqList *L,int i)
{
        int j;
        if(i<0||i>L->n-1)        //小标i是否越界
                return ERROR;
        if(!L->n)        //顺序表是否为空
                return ERROR;
        for(j=i+1; j<L->n; j++)
                L->element[j-1]=L->element[j];        //从前往后逐个前移元素
        L->n--;        //表长减1
        return OK;
}

Status Output(SeqList *L)
{
        int i;
        if(L->n==0)
                return ERROR;
        for(i=0; i<L->n-1; i++)
                printf("%d ",L->element[i]);
        printf("\n");
        return OK;
}

void Destroy(SeqList *L)
{
        L->n=0;
        L->maxLength=0;
        free(L->element);
}

int main()
{
        int i;
        SeqList list;
        Init(&list,10);        //初始化线性表
        for(i=0; i<10; i++)
                Insert(&list,i-1,i);        //线性表中插入新元素
        Output(&list);
        Delete(&list,0);
        Output(&list);
        Destroy(&list);
        return 0;
}
最佳答案
2023-3-3 23:03:00
不出所料这应该是自己写出来的代码。
首先猜猜你的想法:n, maxlength在使用时是重点。
typedef struct seqList
{
        int n;                                // 已存元素数量
        int maxLength;                // 能存元素的最大数量
        ElemType *element;
} SeqList;

然后是:
Insert();函数,你这只是单单的实现的顺序存放,并没有真正的插入功能吧。头插, 中插,尾插。

随后我关键改动几处,自已对比的函数之间的差别。
#include<stdio.h>
#include<stdlib.h>

typedef int ElemType;
typedef struct seqList
{
        int n;                                // 已存元素数量
        int maxLength;                // 能存元素的最大数量
        ElemType *element;
} SeqList;

#define ERROR 0
#define OK 1
#define Overflow 2                //Overflow 表示上溢 
#define Underflow 3        //Underflow 表示下溢
#define NotPresent 4        //Notpresent 表示元素不存在
#define Duplicate 5        //Duplicate 表示有重复元素
typedef int Status;
Status Init(SeqList *L,int mSize)
{
        L->maxLength = mSize;
        L->n = 0;
        L->element = (ElemType*)malloc(sizeof(ElemType)*mSize);                //动态生成一维数组空间
        if(!L->element)
                return ERROR;
        return OK;
}


Status Insert(SeqList *L,int i, ElemType x)
{

        if(L->n==L->maxLength)        // 判断顺序表存储空间是否已满
                return ERROR;

        L->element[i]=x;        
                L->n=L->n+1;
        return OK;
}


Status Output(SeqList *L)
{
        int i;
        if(L->n==0)
                return ERROR;
        for(i=0; i<L->n; i++)
                printf("%d ",L->element[i]);
        printf("\n");
        return OK;
}


int main()
{
        int i;
        SeqList list;
        Init(&list,10);        //初始化线性表
        for(i=0; i<10; i++)
                Insert(&list,i,i);        //线性表中插入新元素
                printf("%d\n", list.n);
        Output(&list);

        return 0;
}
 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-3-3 23:03:00 | 显示全部楼层    本楼为最佳答案   
不出所料这应该是自己写出来的代码。
首先猜猜你的想法:n, maxlength在使用时是重点。
typedef struct seqList
{
        int n;                                // 已存元素数量
        int maxLength;                // 能存元素的最大数量
        ElemType *element;
} SeqList;

然后是:
Insert();函数,你这只是单单的实现的顺序存放,并没有真正的插入功能吧。头插, 中插,尾插。

随后我关键改动几处,自已对比的函数之间的差别。
#include<stdio.h>
#include<stdlib.h>

typedef int ElemType;
typedef struct seqList
{
        int n;                                // 已存元素数量
        int maxLength;                // 能存元素的最大数量
        ElemType *element;
} SeqList;

#define ERROR 0
#define OK 1
#define Overflow 2                //Overflow 表示上溢 
#define Underflow 3        //Underflow 表示下溢
#define NotPresent 4        //Notpresent 表示元素不存在
#define Duplicate 5        //Duplicate 表示有重复元素
typedef int Status;
Status Init(SeqList *L,int mSize)
{
        L->maxLength = mSize;
        L->n = 0;
        L->element = (ElemType*)malloc(sizeof(ElemType)*mSize);                //动态生成一维数组空间
        if(!L->element)
                return ERROR;
        return OK;
}


Status Insert(SeqList *L,int i, ElemType x)
{

        if(L->n==L->maxLength)        // 判断顺序表存储空间是否已满
                return ERROR;

        L->element[i]=x;        
                L->n=L->n+1;
        return OK;
}


Status Output(SeqList *L)
{
        int i;
        if(L->n==0)
                return ERROR;
        for(i=0; i<L->n; i++)
                printf("%d ",L->element[i]);
        printf("\n");
        return OK;
}


int main()
{
        int i;
        SeqList list;
        Init(&list,10);        //初始化线性表
        for(i=0; i<10; i++)
                Insert(&list,i,i);        //线性表中插入新元素
                printf("%d\n", list.n);
        Output(&list);

        return 0;
}
 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-17 21:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表