复习过程中的回顾(纯C语言版),如有不足,请批评指正。
/*顺序表*/
#include<stdio.h>
#include<stdlib.h>
#define ElemType int
#define INITSIZE 80
#define INCRESEMENT 10
typedef struct{
ElemType *elem; //动态申请空间
int length; //数组的当前个数
int maxSize; //数组的最大容量
}SeqList;
int InitList(SeqList *L); //初始化顺序表
int InputList(SeqList *L, ElemType a[], int n); //通过数组给顺序表赋值
void OutputList(SeqList L); //输出顺序表
int ListInsert(SeqList *L, int k, ElemType e); //插入操作,在顺序表L的第k个位置插入元素e
int ListDelete(SeqList *L, int k, ElemType *e); //删除第k个元素,并用e返回删除元素的值
void DestroyList(SeqList *L); //销毁顺序表申请的空间
void main(){
SeqList L; //如果L写成指针类型的话,即SeqList *L;就需要在主函数中申请空间 L = (SeqList*)malloc(sizeof(SeqList));
ElemType a[] = { 1, 2, 3, 4, 6, 5, 9, 6, 3 };
ElemType e;
InitList(&L);
InputList(&L, a, 9);
OutputList(L);
ListDelete(&L, 1, &e);
OutputList(L);
DestroyList(&L);
}
//初始化顺序表
int InitList(SeqList *L){
L->