数据结构C语言实现系列——线性表

2008-02-23 05:40:23来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

#include <stdio.h>
#include
<stdlib.h>
typedef
int elemType;
/************************************************************************/
/* 以下是关于线性表顺序存储操作的16种算法 */
/************************************************************************/
struct List{
elemType
*list;
int size;
int maxSize;
};

void againMalloc(struct List *L)
{
/* 空间扩展为原来的2倍,并由p指针所指向,原内容被自动拷贝到p所指向的存储空间 */
elemType
*p = realloc(L->list, 2 * L->maxSize * sizeof(elemType));
if(!p){ /* 分配失败则退出运行 */
printf(
"存储空间分配失败! ");
exit(
1);
}
L
->list = p; /* 使list指向新线性表空间 */
L
->maxSize = 2 * L->maxSize; /* 把线性表空间大小修改为新的长度 */
}

/* 1.初始化线性表L,即进行动态存储空间分配并置L为一个空表 */
void initList(struct List *L, int ms)
{
/* 检查ms是否有效,若无效的则退出运行 */
if(ms <=

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: 什么是迭代跟递归算法?二者有什么区别?

下一篇: 谈函数指针(全局/类成员函数)和函数对象