博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据结构实践项目——顺序表
阅读量:5748 次
发布时间:2019-06-18

本文共 1945 字,大约阅读时间需要 6 分钟。

本组项目针对《》课程第1-7节

1. 导学
2. 线性表的逻辑结构与基本运算
3. 线性表的顺序存储结构
4. 创建线性表的实现(暨参数类型的讨论)
5. 顺序表基本运算的实现
6. 线性表顺序存储的应用
7. 实践指导:用程序实践算法

【项目1 - 顺序表的基本运算】

  领会“”部分建议的方法,将顺序表部分的算法变成程序。
  实现顺序表基本运算有算法(对应视频和),依据“最小化”的原则进行测试。所谓最小化原则,指的是利用尽可能少的基本运算,组成一个程序,并设计main函数完成测试。
  作为第一个这种类型的实践(后续每一部分均有这种实践,这是我们学习的基础,也是实践成果积累的基础),结合相关的算法,给出建议的过程:
  (1)目的是要测试“建立线性表”的算法CreateList,为查看建表的结果,需要实现“输出线性表”的算法DispList。在研习DispList中发现,要输出线性表,还要判断表是否为空,这样,实现判断线性表是否为空的算法ListEmpty成为必要。这样,再加上main函数,这个程序由4个函数构成。main函数用于写测试相关的代码。
程序的结构如下所示:

#include <....>   //必要的库文件包括#define ...       //必要的宏定义//声明实现算法的自定义函数,以及其他必要的自定义函数//定义用于驱动测试的main函数int main(){    return 0;}//定义各个自定义函数

  若在上面的指导性提示基础上还难于下手,请到课程主页,找到相关链接,观摩后再做。

  切记:(1)无从下手时,要找到参考,这是要“借力”;(2)找到参考,并未解决问题,观摩之后,丢开参考,自行完成,这是根本的目标。用这样的“抄之有道”,抄来的在心里,最终的成果,来自你的心中、脑中和手中。
  (2)在已经创建线性表的基础上,求线性表的长度ListLength、求线性表L中指定位置的某个数据元素GetElem、查找元素LocateElem的算法都可以实现了。就在原程序的基础上增加:
  增加求线性表的长度ListLength的函数并测试;
  增加求线性表L中指定位置的某个数据元素GetElem的函数并测试;
  增加查找元素LocateElem的函数并测试;
  (3)其余的4个基本运算:插入数据元素ListInsert、删除数据元素ListDelete、初始化线性表InitList、销毁线性表DestroyList都可以同法完成,请自行安排实践路线。
  请完成后,发布博文,展示你的实践成果。
[]

【项目2 - 建设“顺序表”算法库】

  领会“0207将算法变程序”部分建议的方法,建设自己的专业基础设施算法库。这一周,建的是顺序表的算法库。
  算法库包括两个文件:
  头文件:list.h,包含定义顺序表数据结构的代码、宏定义、要实现算法的函数的声明;
  源文件:list.cpp,包含实现各种算法的函数的定义
  请采用程序的多文件组织形式,在项目1的基础上,建立如上的两个文件,另外再建立一个源文件,编制main函数,完成相关的测试工作。
  请完成后,发布博文,展示你的实践成果。
[]  

【项目3 - 求集合并集】

  假设有两个集合 A 和 B 分别用两个线性表 LA 和 LB 表示,即线性表中的数据元素即为集合中的成员。设计算法,用函数unionList(List LA, List LB, List &LC )函数实现该算法,求一个新的集合C=A∪B,即将两个集合的并集放在线性表LC中。

提示:

(1)除了实现unnionList函数外,还需要在main函数中设计代码,调用unionList进行测试和演示;
(2)可以充分利用前面建好的算法库,在程序头部直接加 #include<list.h>即可(工程中最普遍的方法,建议采纳);
(3)也可以将实现算法中需要的线性表的基本运算对应的函数,与自己设计的所有程序放在同一个文件中。

  请完成后,发布博文,展示你的实践成果。

[]

【项目4 - 顺序表应用】

  定义一个采用顺序结构存储的线性表,设计算法完成下面的工作:
  1、删除元素在[x, y]之间的所有元素,要求算法的时间复杂度为O(n),空间复杂度为O(1);
  2、将所在奇数移到所有偶数的前面,要求算法的时间复杂度为O(n),空间复杂度为O(1)。

提示:

(1)充分利用前面建立的算法库解决建立顺序表、输出线性表的问题;
(2)为保证复杂度的要求,设计算法并用专门的函数实现算法;
(3)每项工作写一个程序,并发布博文,展示你的实践成果。
[]

转载地址:http://nurzx.baihongyu.com/

你可能感兴趣的文章
如何使用metasploit挖掘邮箱地址
查看>>
[New Portal]SQL Azure(十二) 使用新Portal 创建 SQL Azure Database
查看>>
页_SQL Server 中数据存储的基本单位
查看>>
Node.js 网页瘸腿爬虫初体验
查看>>
简单文章管理系统
查看>>
网络基础
查看>>
[MFC] 从文件读取与向文件添加数据
查看>>
ABP理论学习之领域服务
查看>>
Python之冒泡排序
查看>>
写的好帮手项目官员 - Evernote 5.4(Evernote的) 中国绿色版
查看>>
HTML最新标准HTML5小结
查看>>
RGB和YUV之比较【转】
查看>>
Windows 8 metro 真机调试程序
查看>>
PreparedStatement与Statement
查看>>
[Android Pro] DES加密 version1
查看>>
RDD.scala(源码)
查看>>
ASP.NET Razor - C# 变量
查看>>
[Step By Step]SAP HANA PAL多项式回归预测分析Polynomial Regression编程实例FORECASTWITHPOLYNOMIALR(预测)...
查看>>
JavaScript 函数replace揭秘
查看>>
Fedora9常用网络调试
查看>>