第三周--顺序表的基本运算1

来源:互联网 发布:linux inode 耗尽解决 编辑:程序博客网 时间:2024/06/07 00:14
/*  *Copyright(c)2014,烟台大学计算机与控制工程学院  *All rights reserved.  *文件名称:test.cpp  *作者:杨珺  *完成日期:2015年9月7日  *版本号:v1.0  * *问题描述:实现顺序表基本运算有算法,依据“最小化”的原则进行测试。           所谓最小化原则,指的是利用尽可能少的基本运算,组成一个程序,并设计main函数完成测试。*/#include <stdio.h>#include <malloc.h>#define MaxSize 50    //Maxsize将用于后面定义存储空间的大小typedef int ElemType;  //ElemType在不同场合可以根据问题的需要确定,在此取简单的inttypedef 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 ListLength(SqList *L);//求线性表的长度bool GetElem(SqList *L,int i,ElemType &e);//求线性表中某个数据元素的值int LocateElem(SqList *L,ElemType e);//按元素值查找LocateElem(L,e)//实现测试函数int main(){    SqList *sq;    ElemType x[6]= {5,8,7,2,4,9};ElemType a;int loc;    CreateList(sq, x, 6);    DispList(sq);    printf("表长度:%d\n", ListLength(sq));    if(GetElem(sq, 3, a))  //测试在范围内的情形        printf("找到了第3个元素值为:%d\n", a);    else        printf("第3个元素超出范围!\n");    if(GetElem(sq, 15, a))  //测试不在范围内的情形        printf("找到了第15个元素值为:%d\n", a);    else        printf("第15个元素超出范围!\n");    if((loc=LocateElem(sq, 8))>0)  //测试能找到的情形        printf("找到了,值为8的元素是第 %d 个\n", loc);    else        printf("值为8的元素木有找到!\n");    if((loc=LocateElem(sq, 17))>0)  //测试不能找到的情形        printf("找到了,值为17的元素是第 %d 个\n", loc);    else        printf("值为17的元素木有找到!\n");    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);}//求线性表的长度ListLength(L)int ListLength(SqList *L){return (L->length);}//求线性表中某个数据元素值GetElem(L,i,e)bool GetElem(SqList *L,int i,ElemType &e){if(i<1||i>L->length)return false;e=L->data[i-1];return true;}//按元素值查找LocateElem(L,e)int LocateElem(SqList *L, ElemType e){    int i=0;    while (i<L->length && L->data[i]!=e) i++;    if (i>=L->length)        return 0;    else        return i+1;}


运行结果:

知识点总结:

        实现线性表的基本运算:(1)初始化线性表InitList(&L):构造一个空的线性表L(2)销毁线性表DestroyList(&L):释放线性表L占用的内存空间(3)判线性表是否为空表ListEmpty(L):若L为空表,则返回真,否则返回假(4)求线性表的长度ListLength(L):返回L中元素个数(5)输出线性表DispList(L):当线性表L不为空时,顺序显示L中各节点的值域(6)求线性表L中指定位置的某个数据元素GetElem(L,i,&e):用e返回L中第i 个元素的值(7)查找元素LocateElem(L,e):返回线性表L中第1个与e相等的序号,找不到返回0。

        在编写程序的时候,要注意在main函数中、声明函数时的用法,特别是GetElem函数和LocateElem函数在main函数中注意细节。

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 狗狗牙齿松动了怎么办 狗狗牙齿掉了怎么办 眼镜金属架断了怎么办 纯钛眼镜架断了怎么办 万次火柴没油了怎么办 火疖子破了流脓怎么办 火疖子没有脓头怎么办 孕妇长火疖子疼怎么办 手上长小水泡痒怎么办 脚上起水泡很痒怎么办 手指上有水泡痒怎么办 手指起小水泡痒怎么办 手过敏起小水泡怎么办 头皮上白色像癣怎么办 脸上长了火疖子怎么办 脸上长硬硬的包怎么办 下身体痒痒得不得了怎么办 头皮干痒头屑多怎么办 头发掉的露头皮怎么办 头上老是有结痂怎么办 婴儿头上的黄痂怎么办 头皮屑多又痒怎么办小偏方 皮肤瘙痒起红疙瘩怎么办 头又油又痒怎么办 头上反复长脓包怎么办 额头上长了粉刺怎么办 身上长红疙瘩很痒怎么办 脸上的痘痘变硬怎么办 痘痘变成硬疙瘩怎么办 痘痘变硬了怎么办知乎 痘痘里面是硬的怎么办 皮肤出油毛孔大怎么办 蹭无线网信号差怎么办 无线网离得太远怎么办 无线网不好使了怎么办 火疖子化脓破了怎么办 脸上长了个疖子怎么办 脸上起了火疖子怎么办 脸上长了火疙瘩怎么办 脸上长疖子了该怎么办? 头上神经线疼怎么办