第3周【项目1
来源:互联网 发布:com域名续费多少钱 编辑:程序博客网 时间:2024/06/03 20:13
/* *Copyright(c)2017,烟台大学计算机学院 *All right reserved. *文件名称:20170920.cpp *作者:李小同 *完成日期;2017年9月20日 *版本号;v1.1 * *问题描述:实现顺序表基本运算有算法,依据“最小化”的原则进行测试 *输入描述:建立线性表 *程序输出:输出线性表*/
(1)测试“建立线性表”的算法CreateList,为查看建表的结果,需要实现“输出线性表”的算法DispList。要输出线性表,还要判断表是否为空。
#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 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);}运行结果:
(2)在已经创建线性表的基础上,求线性表的长度ListLength、求线性表L中指定位置的某个数据元素GetElem、查找元素LocateElem。
//自定义函数声明部分void CreateList(SqList *&L, ElemType a[], int n);//用数组创建线性表void DispList(SqList *L);//输出线性表DispList(L)bool ListEmpty(SqList *L);//判定是否为空表ListEmpty(L)int ListLength(SqList *L); //求线性表的长度ListLength(L)bool GetElem(SqList *L,int i,ElemType &e); //求某个数据元素值GetElem(L,i,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;}
运行结果:
(3)其余的4个基本运算:插入数据元素ListInsert、初始化线性表InitList都可以同法完成。
//自定义函数声明部分bool ListInsert(SqList *&l,int i,ElemType e);//插入数据元素void InitList(SqList *&L);//初始化线性列表void DispList(SqList *L);//输出线性表bool ListEmpty(SqList *L);//判定是否为空表//初始化线性列表void InitList(SqList *&L){ L=(SqList *)malloc(sizeof(SqList)); L->length=0;}//插入数据元素bool ListInsert(SqList *&L,int i,ElemType e){ int j; if(i<1||i>L->length+1) return false; i--; for(j=L->length;j>i;j--) L->data[j]=L->data[j-1]; L->data[i]=e; L->length++; return true;}//判定是否为空表ListEmpty(L)bool ListEmpty(SqList *L){ return(L->length==0);}//输出线性表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");}//实现测试函数int main(){ SqList *sq; InitList(sq); ListInsert(sq, 1, 5); ListInsert(sq, 2, 3); ListInsert(sq, 1, 4); DispList(sq); return 0;}
运行结果:
知识点总结:(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
(8)插入元素ListInsert(&L,i, &e):在线性表L中的第i个位置插入元素e;
(9)删除元素ListDelete(&L,i, &e):在线性表L中删除第i个元素,有e返回删除的值;
这九个要点可以作为一个顺序表的基本套路使用。
学习心得:
学会参考,将参考到的东西融入自己的心里,才是最值得的东西
阅读全文
0 0
- 第3周【项目1
- 第8周项目1:任务3:
- 第11周项目1(3)
- 第14周项目1任务3
- 第17周项目1(3)
- 第8周项目3(1)
- 第10周项目1(3)
- 第11周项目1-3
- 第12周项目3(1)-阶乘
- 第13周项目1(3)
- 第13周项目1-(3)
- 第13周项目1-3
- 第15周项目3-(1)
- 第3周项目1三角形
- 第3周项目1-三角形类
- 第6周项目1(3)
- 第7周项目1(3)
- 第3周-项目1-个人所得税计算器
- struts2整合jasperreport打印多张报表
- Windows平台查看连接过的WiFi账号及密码(来自一位技术大牛)
- 【Solidity】使用编译器
- Vue.js快速入门示例
- 欢迎使用CSDN-markdown编辑器
- 第3周【项目1
- Linux下安装JDK/安装Tomcat
- 开机广播,当开机的时候播放音乐
- tp框架的伪静态和真静态页面设置
- 0/1背包问题(二)---动态规划
- 快速实现实现RecycleView的二级菜单,简单易懂
- 陶梅霞, 主研方向为物理层网络编码、无线资源分配、MIMO技术及物理层安全
- 复数类Complex
- Vue学习笔记一 创建vue项目