数据结构实践——顺序表的基本运算
2015-09-14 16:47
246 查看
/* Copyright (c) 2014,烟台大学计控学院 All rights resreved. 文件名称:replace.cpp 作 者:唐子健 完成日期:2015年9月14号 问题描述:交换两个整型变量的swap函数 程序输出:两个整数 */
问题描述:"建立线性表"的算法CreateList,以及查看建表结果的算法DispList,
输入描述:无
程序输出:线性表的结果
#include <stdio.h> #include <malloc.h> #define MaxSize 50 //Maxsize将用于后面定义存储空间的大小 typedef int ElemType; //ElemType在不同场合可以根据问题的需要确定,在此取简单的int typedef struct { ElemType data[MaxSize]; //利用了前面MaxSize和ElemType的定义 int length; } SqList; //自定义函数声明部分 void CreateList(SqList *&L, ElemType a[], int n);//用数组创建线性表 void DispList(SqList *L);//输出线性表DispList(L) bool ListEmpty(SqList *L);//判定是否为空表ListEmpty(L) //实现测试函数 int main() { SqList *sq; ElemType x[6]= {5,8,7,2,4,9}; CreateList(sq, x, 6); DispList(sq); return 0; } //下面实现要测试的各个自定义函数 //用数组创建线性表 void CreateList(SqList *&L, ElemType a[], int n) { int i; L=(SqList *)malloc(sizeof(SqList)); for (i=0; i<n; i++) L->data[i]=a[i]; L->length=n; } //输出线性表DispList(L) void DispList(SqList *L) { int i; if (ListEmpty(L)) return; for (i=0; i<L->length; i++) printf("%d ",L->data[i]); printf("\n"); } //判定是否为空表ListEmpty(L) bool ListEmpty(SqList *L) { return(L->length==0); }
运行结果:
测试“建立线性表”的算法CreateList,为查看建表的结果,需要实现“输出线性表”的算法DispList。要输出线性表,还要判断表是否为空,这样,实现判断线性表是否为空的算法ListEmpty成为必要。这样,再加上main函数,这个程序由4个函数构成。
相关文章推荐
- 程序员求职成功路(2) - 第3章 数据结构与算法
- 程序员面试宝典-2(数据结构与算法)
- *第三周*数据结构实践项目一【顺序表的基本运算】
- 数据结构,算法与应用(4)
- 【顺序表项目1 - 顺序表的基本运算】
- 数据结构,算法与应用(3)
- 数据结构,算法与应用(2)
- 数据结构,算法与应用(1)
- 第2周SHH数据结构—【项目3-体验复杂度(1)】
- 数据结构实验一:顺序表
- 栈的基本操作-数据结构
- 数据结构之栈的链式存储7-(入栈,出栈等)
- 【前端也要学点数据结构】 神奇的树状数组
- 数据结构之栈的顺序存储6-(入栈,出栈等)
- Machine Learning On Spark——第二节:基础数据结构(二)
- 将合并的数据结构来实现一个单一的列表
- KMP算法
- 数据结构 前言
- 软考视频A总结
- 数据结构学习2--线性表的设计与实现(二)