- 7
- 0
- 约7.62千字
- 约 13页
- 2017-08-26 发布于河南
- 举报
数据结构(C语言)-顺序表操作
数据结构(C语言)-顺序表操作
#include stdio.h
#include stdlib.h
#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define INFEASIBLE -1
#define OVERFLOW -2
typedef int ElemType;
typedef int Status;
// 线性表顺序存储结构
#define LIST_INIT_SIZE 100
#define LISTINCREMENT 10
typedef struct{
ElemType *elem;
int length;
int listsize;
}SqList;
Status InitList_Sq(SqList L){
// 构造一个空的线性表L。
L.elem = (ElemType *)malloc(LIST_INIT_SIZE * sizeof(ElemType));
if (! L.elem) exit(OVERFLOW); // 存储分配失败
L.length = 0; // 空表长度为0
L.listsize = LIST_INIT_SIZE; // 初始存储容量
return OK;
} // InitList_Sq
Status DestroyList_Sq(SqList L){
// 销毁线性表 L。
if (L.elem){
L.length = 0;
L.listsize = 0;
free(L.elem);
}
return OK;
} // DestroyList_Sq
Status ListEmpty_Sq(SqList L){
// 判断线性表是否为空。
if (L.length == 0) return TRUE;
else return ERROR;
} // ListEmpty_Sq
Status ClearList_Sq(SqList L){
// 清空线性表 L。
if (! ListEmpty(L)){
for (int i = 0; i L.length; i++)
L.elem[i] = 0;
L.length = 0;
}
return OK;
} // ClearList_Sq
Status ListLength_Sq(SqList L){
// 返回线性表的长度。
return L.length;
} // ListLength_Sq
Status GetElem_Sq(SqList L, int i, ElemType e){
// 用 e 返回线性表的第 i 个元素。
if (i = 0 || i L.length) return ERROR;
else{
e = L.elem[i - 1]; return OK;
}
} // GetElem_Sq
Status LocateElem_Sq(SqList L, ElemType e, Status (*compare)(ElemType, ElemType)){
// 在顺序线性表 L 中查找第 1 个值和 e 满足 compare() 的元素的位序。
// 若找到,则返回其在 L 中的位序,否则返回 0
int i = 1;
ElemType *p = L.elem;
while (i = L.length !(*compare)(*p++, e)) ++i;
if (i = L.length) return i;
else return 0;
} // LocateElem_Sq
Status PriorElem_Sq(SqList L, ElemType cur_e, ElemType pre_e){
// 查找直接前驱
for (int i = 1; i L.length; i++)
if (L.elem[i] == cur_e){
pre_e = L.elem[i-1];
return OK;
}
return FALSE;
} // PriorElem_Sq
Status NextElem_Sq(SqList L, ElemType cur_e, ElemType next_e){
// 查找直接后继
for (int i = 0; i L.length; i++)
if (L.elem [i] == cur_e){
next_e = L.elem [i+1];
return OK;
}
return FALSE;
} // Ne
您可能关注的文档
- 意大利艺术歌曲在声乐教学中重要性.doc
- 性别挣扎.doc
- 意思意思.doc
- 意拳推手应注意问题.doc
- 意识,个体无意识及集体无意识.doc
- 意识及无意识区别.doc
- 意识及思维.doc
- 意识境界.doc
- 感光胶分类介绍.doc
- 意识载体:揭开大脑之谜钥匙.doc
- 中国国家标准 GB/T 6675.9-2025玩具安全 第9部分:化学及类似活动的实验玩具.pdf
- 《GB/T 6675.9-2025玩具安全 第9部分:化学及类似活动的实验玩具》.pdf
- GB/T 46975-2025婴童用品 便携式婴儿睡篮技术要求.pdf
- 中国国家标准 GB/T 46975-2025婴童用品 便携式婴儿睡篮技术要求.pdf
- 《GB/T 46975-2025婴童用品 便携式婴儿睡篮技术要求》.pdf
- 《GB/T 6675.14-2025玩具安全 第14部分:指画颜料要求和测试方法》.pdf
- GB/T 6675.14-2025玩具安全 第14部分:指画颜料要求和测试方法.pdf
- 中国国家标准 GB/T 6675.14-2025玩具安全 第14部分:指画颜料要求和测试方法.pdf
- 中国国家标准 GB/T 33772.3-2025质量评定体系 第3部分:印制板及层压板最终产品检验及过程监督用抽样方案的选择和使用.pdf
- 《GB/T 33772.3-2025质量评定体系 第3部分:印制板及层压板最终产品检验及过程监督用抽样方案的选择和使用》.pdf
最近下载
- 2025年全真模拟房地产经纪人协理考试试题及答案.doc VIP
- GB∕T 2421-2020 环境试验 概述和指南.pdf
- 高中数学 《高中数学知识要点及解题方法精粹》.docx VIP
- 麦克维尔变频螺杆式风冷热泵机组PM-MHSV-C004.pdf
- 山东省济南市槐荫区2024-2025学年二年级上册期末测试数学试卷(含答案).pdf VIP
- 《GB_T 17626.5-2019电磁兼容 试验和测量技术 浪涌(冲击)抗扰度试验》专题研究报告.pptx
- CTT2000LM用户手册(维护分册)教程文件.docx VIP
- 2025年山东专升本计算机真题及答案.docx VIP
- 工业和信息化领域数据安全风险评估实施细则.pptx VIP
- 江西省“三新”协同教研共同体2025届高三12月联考生物学试卷(含答案).docx VIP
原创力文档

文档评论(0)