数据结构-1-顺序表的实现

学习资料:数据结构(C语言版)        清华大学出版社

              其中部分函数的解释来源于百度百科……

线性表的顺序表示与实现

线性表的顺序表示:指的是用一组地址连续的存储单元依次存储线性表的数据元素。这种机内表示称作线性表的顺序存储结构或者顺序映像。 关于线性表顺序存储结构的分析:

优点:只要确定了存储线性表的起始位置,线性表中任一数据元素都可以随机存取。 缺点:当作插入或者删除的操作时,需要移动大量的元素。

 

一、准备阶段: 1、开始前关于程序的头文件和宏定义等相关准备如下:

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 using namespace std;
 4 #define TRUE 1
 5 #define FALSE 0
 6 #define OK 1
 7 #define ERROR 0
 8 #define OVERFLOW -2
 9 #define LIST_INIT_SIZE 100
10 #define LISTINCREMENT 10

2、辅助定义:

typedef int Status;
typedef int ElemType;

 定义不同的数据类型名称是为了增强程序的可读性。

日后编写代码长度较大的程序中,若需要进行类型变换(比如换成double)只要写成:“typedef double ElemType; ”就可以了。

3、用结构体构造一个顺序表,定义了顺序表的地址、长度和当前分配的存储容量。代码如下:

1 typedef struct
2 {
3     ElemType *elem;//存储空间的基址
4     int length;//当前长度
5     int listsize;//当前分配的存储容量(以sizeof(ElemType)为单位)
6 } Sqlist;

二、相关函数
1、线性表的初始化

顺序表的初始化操作是为顺序表分配一个预定义大小的输足空间,并且将线性表的当前长度设为0。当空间不足时,可以再一次进行分配,为顺序表增加一个大小为存储LISTINCREMENT个数据元素的空间。

调试时出现的问题:

一开始代码按照书上写为“&L”(第一行)

可是出现“expected ‘)’ before'&’ token”字眼的错误(当时选择了C语言的编译环境)

后来改为'*L'的写法(函数内涉及L的访问用'(*L).'/'(L->)'的写法)可以正常运行(这时我改了C++的编译环境)。

原来这是编译环境的问题。第一种‘&L’的写法在C++的编译环境下是也可以正常编译的。而C的编译环境不支持。

1 Status InitList_Sq(SqList *L)
2 {
3     (*L).elem=(ElemType *)malloc(LIST_INIT_SIZE*sizeof(ElemType));
4     if(!(*L).elem)exit(OVERFLOW);
5     (*L).length=0;
6     (*L).listsize=LIST_INIT_SIZE;
7     return OK;
8 }

在这里用到了malloc函数(动态内存分配):

头文件:#include <stdlib.h>

功能:malloc 向系统申请分配指定size个字节的内存空间。

返回值:如果分配成功则返回指向被分配内存的指针(此存储区中的初始值不确定),否则返回空指针NULL。当内存不再使用时,应使用free()函数将内存块释放。函数返回的指针一定要适当对齐,使其可以用于任何数据对象 。

2、数据的插入

向指定位置pos插入数据e(插入前判断是否需要增加存储空间,若不够就增加分配)。先移动指针再插入e。需要考虑输入的pos是否合法。

 1 Status ListInsert_Sq(SqList *L,int pos,ElemType e)
 2 {
 3     ElemType *newbase,*p,*q;
 4     if(pos<1||pos>(*L).length+1)
 5     {
 6         cout<<"this position is illegal!"<<endl;
 7         return ERROR;
 8     }
 9     if((*L).length>=(*L).listsize)//
  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值