- 1、本文档共31页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
山东建筑大学数据结构课程设计报告课案
山东建筑大学题 目:课 程:
院 (部):
专 业:
班 级:
学生姓名:
学 号:
指导教师:
完成日期:目 录
课程设计任务书 I
课程设计任务书 II
逆邻接链表实现有向图 3
一、问题描述 3
二、数据结构 3
三、逻辑设计 3
四、编码 5
五、测试数据 14
六、 测试情况 16
逆邻接链表实现有向图 17
一、问题描述 17
二、数据结构 17
三、逻辑设计 17
四、编码 19
五、测试数据 27
七、 测试情况 29
结 论 30
课程设计指导教师评语 32
山东建筑大学计算机科学与技术学院
课程设计任务书
设计题目 基于逆邻接表的有向图基本操作的实现 已知技术参数和设计要求 题目三、实现类NetWork,实现BFS、DFS、拓扑排序,并实现采用逆邻接表作为存储结构的有向图,要继承NetWork。逆邻接表要使用STL提供的List和Vector等实现。
设计内容与步骤 设计存储结构
设计算法
编写程序,进行调试
总结并进行演示、讲解 设计工作计划与进度安排 2015.6.17~2015.6.23,实现基类Network和有向图Graph,实现逆邻接链表的存储结构。
2015.6.23~2015.7.1,编写测试代码。
2015.7.1~2015.7.3,改正一些错误,完成实验。 设计考核要求 考勤20%
课程设计说明书50%
成果展示30%
指导教师(签字): 教研室主任(签字)
山东建筑大学计算机科学与技术学院
课程设计任务书
设计题目 双向循环链表 已知技术参数和设计要求 实现双向循环链表。
设计内容与步骤 设计存储结构
设计算法
编写程序,进行调试
总结并进行演示、讲解 设计工作计划与进度安排 2015.4.22~2015.4.35,实现双向循环链表
2015.4.25~2015.4.29,编写测试代码。
设计考核要求 考勤20%
课程设计说明书50%
成果展示30%
指导教师(签字): 教研室主任(签字)逆邻接链表实现有向图
一、问题描述
二、数据结构
三、逻辑设计
1、总体思路
先实现Network类,通过队列实现BFS,通过堆栈实现DFS和拓扑排序。再构建Graph类,并继承Network类实现以逆邻接链表为存储结构的有向图。
2、模块划分(以图示的方法给出各个函数的调用关系)
3、函数或类的具体定义和功能
Network类:
virtual int Begin(int i) = 0;//确定起始顶点
virtual int Nextvertex(int i) = 0;//下一个顶点
virtual int Edges()=0;//确定点
virtual int Vertices()=0;//确定边
virtual void Initializepos(int i)=0;//让迭代器等于链表的第i个顶点的第一个元素
virtual void Deactivatepos(int i)=0;//删除迭代器指的元素
void BFS(int v,int reach[],int label,int a[]);//宽度遍历
void DFS(int v,int reach[],int label,int a[]);//深度遍历
bool Topological(int v[]);//拓扑排序
virtual ~Network();//析构函数
Graph类:
virtual ~Graph();//析构函数
int InDegree(int node);//入度
int OutDegree(int node);//出度
Graph Add(int node1, int node2);//添加点
Graph Delete(int node1, int node2);//删除点
int Begin(int i);//确定起始顶点
int Nextvertex(int i);//下一个顶点
int Edges() {return e;}//确定点
int Vertices() {return n;}//确定边
void Initializepos(int i){pos=al[i].begin(); }////让迭代器等于链表的第i个顶点的第一个元素
void Deactivatepos(int i){al[i].erase(pos);}//删除迭代器指的元素
void Out();//输出函数
四、编码
//Network.h
#include iostream
#includequeue
#includestack
#include vector
using namespace std;
cla
您可能关注的文档
最近下载
- 2025年湖北省襄阳市襄阳四中学初三下学期四月调考化学试题含解析.doc VIP
- GBT 42706.1-2023 电子元器件 半导体器件长期贮存 第1部分:总则.doc
- 2018人教版七年级数学下册练习:期末达标检测卷.docx VIP
- AC-25厂拌热再生沥青混凝土试验段施工方案.doc
- 行业联盟与竞争格局演变-深度研究.pptx
- 2024-2025学年北京西城区九年级初三(上)期末道德与法治试卷(含答案).pdf
- 2025年山东省枣庄市滕州市高三二模物理试卷及答案.docx
- 第九章 压强和浮力(知识清单)【教师版】.docx VIP
- 2025保安员理论考试100题(附答案) .pdf VIP
- 2022年三级教育测试题.docx
文档评论(0)