文档库 最新最全的文档下载
当前位置:文档库 › 数据结构课程设计报告书 2

数据结构课程设计报告书 2

数据结构课程设计报告书 2
数据结构课程设计报告书 2

数据结构课程设计报告书

姓名:邓凯强

学号:20121000952

班级:113121-05

指导老师:张唯老师

成绩:

中国地质大学(武汉)

信息工程学院遥感科学与技术系

2014 年1 月

一、车辆管理子模块

1.需求规格说明

问题描述:

设计合理的数据结构,对校园的车辆信息进行登记管理。提供基本信息的录入、查询和修改功能,结果以特定形式进行展示。

信息录入:能够手动输入指定格式的单个车辆信息,也能够从文本文件中一次性录入多台车辆信息。车辆信息内容可自定义,至少需要包含“车牌号码”、“车主姓名”、“所属单位代码”和“所属单位名称”四个内容,其他内容可根据后续系统的需要自行增加。

图1、文本格式

信息查询:能够根据输入的属性项,查询相应的车辆信息。如输入车牌号码,查询车主信息;或输入车主,查询该车主名下所有车辆的车牌号码;或输入单位名称或代码,查询该单位所有车主或车辆信息。

信息修改:能够对查询到的车辆信息进行编辑和删除。

2.总体分析与设计

(1)设计思想:

(具体内容:存储结构、主要的算法思想。)

主要的算法思想:

考虑到车辆基本信息的数据量,采用文本形式存储原始车辆信息。系统运行过程中,采用线性表存储所有车辆信息。车辆信息录入过程中,可选择适当的排序算法对数据进行排序,方便后续的查找。数据查询中,需要根据查询的关键码,使用合适的搜索算法。

主要考察线性表的建立、插入和删除操作,以及基于线性表的排序和搜索算法。为建立一个统一的系统,建议大家在设计车辆信息结构时,同时兼顾二、三部分子模块的功能需求,选择合适的数据结构。

(2)设计表示:

(具体内容:子程序(过程或函数)的规格说明,通过调用关系图表示它们之间的调用关系)

调用关系图:

(3)详细设计表示:

(<五号宋体>,具体内容:主要算法的框架。)添加的代码:

void CPart1::OnBnClickedButton1() {UpdateData(TRUE);

ofstream infile("data.txt",ios::app);

if (infile.fail())

{

AfxMessageBox(_T("文件未打开"));

return;

}

string num,name,department,code;

num =CT2A(m_num);

name =CT2A(m_name);

code =CT2A(m_code);

department =CT2A(m_department);

CarInf cif;

int judge =0;

for (int i =0;i

{

info.getData(i,cif);

if (num==cif.num) judge++;

if(i==sum) break;

}

if(judge)

{

AfxMessageBox(_T("添加失败,已有此车主信息"));

return;

}

else

{

infile<<'\n'<

MessageBox(_T("添加成功"));

infile.close();

}

CarInf ca;

ca.code =code;

ca.department =department;

ca.num =num;

https://www.wendangku.net/doc/7110746470.html, =name;

info.Insert(info.Length(),ca);

UpdateData(FALSE);

}

修改的代码:

void CPart1::OnBnClickedButton2() // 修改,只支持对车牌编号进行修改

{ UpdateData(TRUE);

ofstream infile("data.txt");

if (infile.fail())

{

AfxMessageBox(_T("文件未打开"));

return;

}

string num,name,department,code;

num =CT2A(m_num);

name =CT2A(m_name);

code =CT2A(m_code);

department =CT2A(m_department);

CarInf cif;

int judge =0;

for (int i =0;i

{

info.getData(i,cif);

if (num==cif.num)

{

cif.code =code;

cif.department =department;

https://www.wendangku.net/doc/7110746470.html, =name;

info.setData(i,cif);

cif.code ="单位编号";

cif.department ="单位名称";

https://www.wendangku.net/doc/7110746470.html, ="车主姓名";

cif.num ="车牌编号";

info.setData(0,cif);

MessageBox(_T("修改成功"));

break;

}

}

for (int i =0;i

{

info.getData(i,cif);

if(i!=sum)

infile<

else infile<

}

UpdateData(FALSE);

}

删除编码:

void CPart1::OnBnClickedButton3()

{ //删除,是根据车牌号删除

UpdateData(TRUE);

ofstream infile("data.txt");

if (infile.fail())

{

AfxMessageBox(_T("文件未打开"));

return;

}

string num,name,department,code;

num =CT2A(m_num);

name =CT2A(m_name);

code =CT2A(m_code);

department =CT2A(m_department);

CarInf cif;

int judge =0;

int count=0;

int sum =info.Length();

for (int i =0;i

{

info.getData(i,cif);

if (num==cif.num)

{

cif.code ="";

cif.department ="";

https://www.wendangku.net/doc/7110746470.html, ="";

cif.num ="";

info.setData(i,cif);

cif.code ="单位代码";

cif.department ="单位名称";

https://www.wendangku.net/doc/7110746470.html, ="车主姓名";

cif.num ="车牌编号?";

info.setData(0,cif);

MessageBox(_T("删除成功"));

break;

}

}

for (int i =0;i

{

info.getData(i,cif);

if (!(cif.num==""&& https://www.wendangku.net/doc/7110746470.html,==""&& cif.code==""&& cif.department==""))

{

if(i!=sum)

infile<

else

infile<

}

}

UpdateData(FALSE);

}

查询编码:

void CPart1::OnBnClickedButton4()

{

//查询,单位名称不支持查询,可根据姓名,车牌号,单位代码三种混合输入查询,共七种方式UpdateData(TRUE);

string name="", num="", department="",code ="";

name =CT2A(m_name);

num =CT2A(m_num);

department =CT2A(m_department);

code =CT2A(m_code);

//////////////////////////////

m_list ="车牌编号单位代码车主姓名单位名称";

if (code!=""&& num==""&& name==""&& department=="")

{

m_search =code.c_str();

CarInf cif;

int sum =info.Length();

for (int i =0;i

{

info.getData(i,cif);

if (code==cif.code)

{

m_department =cif.department.c_str();

m_name =https://www.wendangku.net/doc/7110746470.html,.c_str();

m_num =cif.num.c_str();

CString cstr;

string str ="\t";

cstr =str.c_str();

m_list.Append(m_num);

m_list.Append(cstr);

m_list.Append(m_code);

m_list.Append(cstr);

m_list.Append(m_name);

m_list.Append(cstr);

m_list.Append(m_department);

str ="\r\n";

cstr =str.c_str();

m_list.Append(cstr);

}

if(i==sum)

{

if(m_list=="") AfxMessageBox(_T("查无此学院代码"));

break;

}

}

}

elseif(name!=""&& code==""&& num==""&& department=="")

{

m_search =name.c_str();

CarInf cif;

int sum =info.Length();

for (int i =0;i

{

info.getData(i,cif);

if (name==https://www.wendangku.net/doc/7110746470.html,)

{

m_department =cif.department.c_str();

m_name =https://www.wendangku.net/doc/7110746470.html,.c_str();

m_num =cif.num.c_str();

m_code =cif.code.c_str();

CString cstr;

string str ="\t";

cstr =str.c_str();

m_list.Append(m_num);

m_list.Append(cstr);

m_list.Append(m_code);

m_list.Append(cstr);

m_list.Append(m_name);

m_list.Append(cstr);

m_list.Append(m_department);

str ="\r\n";

cstr =str.c_str();

m_list.Append(cstr);

}

if(i==sum)

{

if(m_list=="") AfxMessageBox(_T("查无此人"));

break;

}

}

}

elseif (num!=""&& code==""&& name==""&& department=="") {

m_search ="";

string s ="车牌编号:";

CString nu;

nu =s.c_str();

m_search.Append(nu);

nu =num.c_str();

m_search.Append(nu);

CarInf cif;

int sum =info.Length();

for (int i =0;i

{

info.getData(i,cif);

if (num==cif.num)

{

m_department =cif.department.c_str();

m_name =https://www.wendangku.net/doc/7110746470.html,.c_str();

m_num =cif.num.c_str();

m_code =cif.code.c_str();

CString cstr;

string str ="\t";

cstr =str.c_str();

m_list.Append(m_num);

m_list.Append(cstr);

m_list.Append(m_code);

m_list.Append(cstr);

m_list.Append(m_name);

m_list.Append(cstr);

m_list.Append(cstr);

m_list.Append(m_department);

str ="\r\n";

cstr =str.c_str();

m_list.Append(cstr);

}

if(i==sum)

{

if(m_list=="") AfxMessageBox(_T("查无此人"));

break;

}

m_department =m_num =m_code =m_name="";

}

}

elseif(name!=""&& code!=""&& num==""&& department=="")

{

m_search =name.c_str();

CarInf cif;

int sum =info.Length();

for (int i =0;i

{

info.getData(i,cif);

if (name==https://www.wendangku.net/doc/7110746470.html, && code==cif.code)

{

m_department =cif.department.c_str();

m_name =https://www.wendangku.net/doc/7110746470.html,.c_str();

m_num =cif.num.c_str();

m_code =cif.code.c_str();

CString cstr;

string str ="\t";

cstr =str.c_str();

m_list.Append(m_num);

m_list.Append(cstr);

m_list.Append(m_code);

m_list.Append(cstr);

m_list.Append(m_name);

m_list.Append(cstr);

m_list.Append(cstr);

m_list.Append(m_department);

str ="\r\n";

cstr =str.c_str();

m_list.Append(cstr);

}

if(i==sum)

{

if(m_list=="") AfxMessageBox(_T("查无此人"));

break;

}

}

}

elseif(name!=""&& code==""&& num!=""&& department=="")

{

m_search =name.c_str();

CarInf cif;

int sum =info.Length();

for (int i =0;i

{

info.getData(i,cif);

if (name==https://www.wendangku.net/doc/7110746470.html, && num==cif.num)

{

m_department =cif.department.c_str();

m_name =https://www.wendangku.net/doc/7110746470.html,.c_str();

m_num =cif.num.c_str();

m_code =cif.code.c_str();

CString cstr;

string str ="\t";

cstr =str.c_str();

m_list.Append(m_num);

m_list.Append(cstr);

m_list.Append(m_code);

m_list.Append(cstr);

m_list.Append(m_name);

m_list.Append(cstr);

m_list.Append(cstr);

m_list.Append(m_department);

str ="\r\n";

cstr =str.c_str();

m_list.Append(cstr);

}

if(i==sum)

{

if(m_list=="") AfxMessageBox(_T("查无此人"));

break;

}

}

}

elseif(name==""&& code!=""&& num!=""&& department=="")

{

m_search =name.c_str();

CarInf cif;

int sum =info.Length();

for (int i =0;i

{

info.getData(i,cif);

if (num==cif.num && code==cif.code)

{

m_department =cif.department.c_str();

m_name =https://www.wendangku.net/doc/7110746470.html,.c_str();

m_num =cif.num.c_str();

m_code =cif.code.c_str();

CString cstr;

string str ="\t";

cstr =str.c_str();

m_list.Append(m_num);

m_list.Append(cstr);

m_list.Append(m_code);

m_list.Append(cstr);

m_list.Append(m_name);

m_list.Append(cstr);

m_list.Append(cstr);

m_list.Append(m_department);

str ="\r\n";

cstr =str.c_str();

m_list.Append(cstr);

}

if(i==sum)

{

if(m_list=="") AfxMessageBox(_T("查无此人"));

break;

}

}

}

elseif(name!=""&& code!=""&& num!=""&& department=="")

{

m_search =name.c_str();

CarInf cif;

int sum =info.Length();

for (int i =0;i

{

info.getData(i,cif);

if (name==https://www.wendangku.net/doc/7110746470.html, && code==cif.code && num==cif.num)

{

m_department =cif.department.c_str();

m_name =https://www.wendangku.net/doc/7110746470.html,.c_str();

m_num =cif.num.c_str();

m_code =cif.code.c_str();

CString cstr;

string str ="\t";

cstr =str.c_str();

m_list.Append(m_num);

m_list.Append(cstr);

m_list.Append(m_code);

m_list.Append(cstr);

m_list.Append(m_name);

m_list.Append(cstr);

m_list.Append(cstr);

m_list.Append(m_department);

str ="\r\n";

cstr =str.c_str();

m_list.Append(cstr);

}

if(i==sum)

{

if(m_list=="") AfxMessageBox(_T("查无此人"));

break;

}

}

}

else

{

AfxMessageBox(_T("不满足查询要求));

}

UpdateData(FALSE);

}

3.编码

(具体内容:问题是如何解决的,编码过程中的困难与解决方法。)

所遇问题:

如果查询的时候是采用混合查询,即输入多个信息进行查询,这个时候如果输入的单位与单位编号不一致就会查询不到该车主。

解决方案:

由于单位与单位编号是唯一对应的,即单位编号只与单位有关,而与车辆信息无关的,所以在查询时,只让单位编号支持查询,而单位不支持查询,也就避免了出现单位编号和单位在查询时不一致的情况。

4.程序及算法分析

(<五号宋体>,具体内容:使用说明、程序运行结果、讨论与分析、改进设想、经验

与体会、时空复杂度等。)

使用说明:在添加信息时,可以直接添加,即在对话框中直接输入车主姓名,车牌号,单位编号和单位名称。

查询截图:

5.小结

(<五号宋体>,具体内容:经验与体会,或需要改进的地方)

当要添加的信息的较多时,最好是在文件中直接输入添加的信息。但是单位和单位代码应该对应,但是都是手动输入的,在输入的过程中可能是一个单位对应着多个单位编号,出现不一致的现象,但是程序中由于是手动输入的,而且这种情况没有报错,这是程序的一个需要改进的地方,但是改进的方法还没找到。

6.附录

(<五号宋体>,部分核心代码)

#include

#include

#include

usingnamespace std;

//Cpart 1对话框

void CPart1::DoDataExchange(CDataExchange* pDX)

{

CDialogEx::DoDataExchange(pDX);

DDX_Text(pDX, IDC_EDIT1, m_name);

DDX_Text(pDX, IDC_EDIT2, m_num);

DDX_Text(pDX, IDC_EDIT3, m_code);

DDX_Text(pDX, IDC_EDIT4, m_department);

DDX_Text(pDX, IDC_EDIT5, m_list);

DDX_Text(pDX, IDC_EDIT6, m_search);

}

BEGIN_MESSAGE_MAP(CPart1, CDialogEx)

ON_BN_CLICKED(IDC_BUTTON1, &CPart1::OnBnClickedButton1) ON_BN_CLICKED(IDC_BUTTON2, &CPart1::OnBnClickedButton2) ON_BN_CLICKED(IDC_BUTTON3, &CPart1::OnBnClickedButton3) ON_BN_CLICKED(IDC_BUTTON4, &CPart1::OnBnClickedButton4) ON_EN_CHANGE(IDC_EDIT5, &CPart1::OnEnChangeEdit5)

ON_EN_CHANGE(IDC_EDIT1, &CPart1::OnEnChangeEdit1)

END_MESSAGE_MAP()

IMPLEMENT_DYNAMIC(CPart1, CDialogEx)

CPart1::CPart1(List &list,CWnd* pParent /*=NULL*/)

: CDialogEx(CPart1::IDD, pParent)

, m_name(_T(""))

, m_num(_T(""))

, m_code(_T(""))

, m_department(_T(""))

, m_list(_T(""))

, m_search(_T("显示框"))

{

CarInf ca;

List li(ca);

int count =0;

ifstream infile("data.txt");

char str[256];

int sum=0;

int count_n=0;

while(!infile.eof())

{

infile.getline(str, sizeof(str));

sum++;

if (*str==NULL) count_n++;

}

sum-=count_n;

infile.close();

ifstream file;

file.open("data.txt");

char infma[256]="";

file.getline(infma,256);

for(int i=0;i

{

file>>ca.num>>https://www.wendangku.net/doc/7110746470.html,>>ca.code>>ca.department;

li.Insert(count++,ca);

file.getline(infma,256);

};

file.close();

list =li;

info =list;

}

(其余几个算法的主程序代码在第三部分)

二、停车收费子模块

1.需求规格说明

(<五号宋体>,具体内容:问题描述,求解的问题是什么)

功能需求

设计合理的数据结构,对出入校园的车辆进行收费管理。提供车辆出入登记收费管理、停车秩序管理功能和车辆当前位置查询功能。

车辆登记和收费管理:车辆进入校门时,记录相应的车牌信息和进校时间。若该车牌信息已经记录在案,表明为校内车辆,停车费用不计。若该车牌信息尚未记录,则该车为校外车辆,停车费用按每小时3元收取。

停车秩序管理:本校区道路较为狭窄,车辆登记后,需要依次排队经过相应的通道后,方可进入校区。如果当前通道中已有车辆,则需等待前方车辆通过后,方可驶入通道。车辆入校的时间,以进入校区的时间为准。校区内建有小型停车场一个,进入停车场的车辆应依次排列。由于通道仅容一辆车进出,因此,后进入停车场的车辆需要先退出后,先进入的车辆方可退出。

车辆当前位置查询:根据输入车牌号,查询相应车辆现在的位置,位置信息可包含“通道”、“停车场”、“教一楼”等。

2.总体分析与设计

(1)设计思想:

(<五号宋体>,具体内容:存储结构、主要的算法思想。)

主要的算法思想:

校内车辆可直接采用一中的线性表来记录相关信息,校外车辆需要建立另外的线性表来记录,也可将出入车辆统一使用一个线性表来记录。进入学校的通道可采用队列来描述,车

辆出队列的时间即为车辆的入校时间。小型停车场可采用堆栈来描述。车辆信息内容可根据三的内容作相应的调整。

(2)设计表示:

(<五号宋体>,具体内容:子程序(过程或函数)的规格说明,通过调用关系图

表示它们之间的调用关系。)

(3)详细设计表示:

(<五号宋体>,具体内容:主要算法的框架。)

3.编码

(<五号宋体>,具体内容:问题是如何解决的,编码过程中的困难与解决方法。)

4.程序及算法分析

(<五号宋体>,具体内容:使用说明、程序运行结果、讨论与分析、改进设想、经验

与体会、时空复杂度等。)

5.小结

(<五号宋体>,具体内容:经验与体会,或需要改进的地方)

6.附录

(<五号宋体>,部分核心代码)

三、路线导航子模块

1.需求规格说明

(<五号宋体>,具体内容:问题描述,求解的问题是什么)

1、功能需求

设计合理的数据结构,对校园的主要道路进行管理。提供主要建筑和基本道路的录入和车辆导航功能。

信息录入:输入校园内的主要建筑物地理位置信息,并在不同建筑之间建立相应的道路网,并以道路的长度作为其权值。设计相应的结构,对建筑和道路信息进行管理。

车辆导航:输入车辆当前位置和目的建筑物名称,系统自动计算从当前位置到该建筑物的最短路径。设计相应的路径表达方式。

2.总体分析与设计

(1)设计思想:

(<五号宋体>,具体内容:存储结构、主要的算法思想。)

主要的算法思想:

最短路径的分析可采用图来描述,其中建筑物为图的顶点,道路为图的边,顶点和边通过坐标进行关联。车辆当前位置可以和二中相结合,也可以重新定义。路径的显示可以输出经过的路径,也可以通过图形进行描述。

(2)设计表示:

(<五号宋体>,具体内容:子程序(过程或函数)的规格说明,通过调用关系图

表示它们之间的调用关系。)

(3)详细设计表示:

(<五号宋体>,具体内容:主要算法的框架。)

以下是对对话框的点击设置程序:

class CPart3 : public CDialogEx

{

DECLARE_DYNAMIC(CPart3)

public:

CPart3(CWnd* pParent = NULL); // 标准构造函数

virtual ~CPart3();

// 对话框数据

enum { IDD = IDD_DIALOG4 };

protected:

virtualvoid DoDataExchange(CDataExchange* pDX);

DECLARE_MESSAGE_MAP()

public:

CEdit m_contr;

afx_msg void OnSize(UINT nType, int cx, int cy);

//CEdit m_1;

virtual BOOL OnInitDialog();

CRect m_rect;

CStatic m_picture;

afx_msg void OnPaint();

void picturedeal();

bool ShowJpgGif(CDC *pDC, CString strPath, int x, int y);

CComboBox m_begin;

CComboBox m_end;

CGraphlnk G;

afx_msg void OnBnClickedButton1();

afx_msg void OnCbnSelchangeCombo2();

};

3.编码

(<五号宋体>,具体内容:问题是如何解决的,编码过程中的困难与解决方法。)

问题描述:开始时不知道地图的信息应该如何输入,导航的功能如何在实物地图上来实现。解决方案:实物地图由下载的文件来读入信息,填入每个路标的坐标信息以及没两个路标之间的权值,再根据两顶点之间权值最小来确定应该走的路线。

4.程序及算法分析

(<五号宋体>,具体内容:使用说明、程序运行结果、讨论与分析、改进设想、经验

与体会、时空复杂度等

导航系统的截图:

数据结构课程设计参考题目

数据结构课程设计题目 数据结构课程设计题目(大题目).doc 一、公司销售管理系统 项目开发基本要求 1.客户信息管理:对客户的基本信息进行添加、修改和删除。 2.产品信息管理:对产品的基本信息进行添加、修改和删除。 3.供应商信息管理:对供应商的基本信息进行添加、修改和删除。 4.订单信息管理:对订单的基本信息进行添加、修改和删除。 二、高校科研管理系统 系统主要用于帮助高校或科研单位管理和维护各项科研相关资料 项目开发基本要求 1.系统用户管理模块:为系统新用户设置用户名及口令;操作员更改自己的系统口令。2.数据字典管理模块:管理项目性质包括:分为国家自然科学基金、863、部省科委及企业集团四种情况;范围包括:分为全国、国际、地方三种情况;检索源包括:分为EI、SCI、核心和一般四种情况。 3.项目参加人员管理模块包括:显示添加修改删除查询。 4.项目基本情况模块包括:显示添加修改删除查询。 5.项目获奖情况模块包括:显示添加修改删除查询。 6.期刊论文管理模块包括:显示添加修改删除查询。 7.著作管理模块包括:显示添加修改删除查询。 8.科研工作量统计模块:按照学校科研工作量计算办法,为每位科研人员进行科研工作量的计算和统计。 9.科研积分统计模块:按照学校科研积分计算办法,为每位科研人员进行科研计分的计算和统计。 三、网络五子棋对战 四、不同排序算法模拟 五、科学计算器 数据结构课程设计题目 1.运动会分数统计 任务:参加运动会有n个学校,学校编号为1……n。比赛分成m个男子项目,和w个女子项目。项目编号为男子1……m,女子m+1……m+w。不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或前三名由学生自己设定。(m<=20,n< =20) 功能要求: 1)可以输入各个项目的前三名或前五名的成绩; 2)能统计各学校总分,

数据结构课程设计

1.一元稀疏多项式计算器 [问题描述] 设计一个一元稀疏多项式简单计算器。 [基本要求] 输入并建立多项式; 输出多项式,输出形式为整数序列:n, c1, e1, c2, e2,……, cn, en ,其中n是多项式的项数,ci, ei分别是第i项的系数和指数,序列按指数降序排序; 多项式a和b相加,建立多项式a+b; 多项式a和b相减,建立多项式a-b; [测试数据] (2x+5x8-3.1x11)+(7-5x8+11x9)=(-3.1x11+11x9+2x+7) (6x-3-x+4.4x2-1.2x9)-(-6x-3+5.4x2-x2+7.8x15)=(-7.8x15-1.2x9-x+12x-3) (1+x+x2+x3+x4+x5)+(-x3-x4)=(x5+x2+x+1) (x+x3)+(-x-x3)=0 (x+x2+x3)+0=(x3+x2+x) [实现提示] 用带头结点的单链表存储多项式,多项式的项数存放在头结点中。 2.背包问题的求解 [问题描述] 假设有一个能装入总体积为T的背包和n件体积分别为w1, w2, …,wn的物品,能否从n件物品中挑选若干件恰好装满背包,即使w1+w2+…+wn=T,要求找出所有满足上述条件的解。例如:当T=10,各件物品的体积为{1,8,4,3,5,2}时,可找到下列4组解:(1,4,3,2)、(1,4,5)、(8,2)、(3,5,2) [实现提示] 可利用回溯法的设计思想来解决背包问题。首先,将物品排成一列,然后顺序选取物品转入背包,假设已选取了前i件物品之后背包还没有装满,则继续选取第i+1件物品,若该件物品“太大”不能装入,则弃之而继续选取下一件,直至背包装满为止。但如果在剩余的物品中找不到合适的物品以填满背包,则说明“刚刚”装入背包的那件物品“不合适”,应将它取出“弃之一边”,继续再从“它之后”的物品中选取,如此重复,直至求得满足条件的解,或者无解。 由于回溯求解的规则是“后进先出”因此自然要用到栈。 3.完全二叉树判断 用一个二叉链表存储的二叉树,判断其是否是完全二叉树。 4.最小生成树求解(1人) 任意创建一个图,利用克鲁斯卡尔算法,求出该图的最小生成树。 5.最小生成树求解(1人) 任意创建一个图,利用普里姆算法,求出该图的最小生成树。 6.树状显示二叉树 编写函数displaytree(二叉树的根指针,数据值宽度,屏幕的宽度)输出树的直观示意图。输出的二叉树是垂直打印的,同层的节点在同一行上。 [问题描述] 假设数据宽度datawidth=2,而屏幕宽度screenwidth为64=26,假设节点的输出位置用 (层号,须打印的空格数)来界定。 第0层:根在(0,32)处输出;

数据结构课程设计报告模板

《数据结构I》三级项目报告 大连东软信息学院 电子工程系 ××××年××月

三级项目报告注意事项 1. 按照项目要求书写项目报告,条理清晰,数据准确; 2. 项目报告严禁抄袭,如发现抄袭的情况,则抄袭者与被抄袭者均 以0分计; 3. 课程结束后报告上交教师,并进行考核与存档。 三级项目报告格式规范 1. 正文:宋体,小四号,首行缩进2字符,1.5倍行距,段前段后 各0行; 2. 图表:居中,图名用五号字,中文用宋体,英文用“Times New Roman”,位于图表下方,须全文统一。

目录 一项目设计方案 (3) 二项目设计分析 (4) 三项目设计成果 (4) 四项目创新创业 (5) 五项目展望 (6) 附录一:项目成员 (6) 附录二:相关代码、电路图等 (6)

一项目设计方案 1、项目名称: 垃圾回收 2、项目要求及系统基本功能: 1)利用数据结构的知识独立完成一个应用系统设计 2)程序正常运行,能够实现基本的数据增加、删除、修改、查询等功能3)体现程序实现算法复杂度优化 4)体现程序的健壮性 二项目设计分析 1、系统预期实现基本功能: (结合本系统预期具体实现,描述出对应基本要求(增、删、改、查等)的具体功能) 1. 2. 3. 4. 5. 6. 7. 2、项目模块功能描述 (基本分为组织实施组织、程序功能模块编写、系统说明撰写等。其中程序功能子模块实现) 模块一: 主要任务:XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX 模块二: 主要任务:XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX 模块n: 主要任务:XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

数据结构实验总结报告

数据结构实验总结报告 一、调试过程中遇到哪些问题? (1)在二叉树的调试中,从广义表生成二叉树的模块花了较多时间调试。 由于一开始设计的广义表的字符串表示没有思考清晰,处理只有一个孩子的节点时发生了混乱。调试之初不以为是设计的问题,从而在代码上花了不少时间调试。 目前的设计是: Tree = Identifier(Node,Node) Node = Identifier | () | Tree Identifier = ASCII Character 例子:a(b((),f),c(d,e)) 这样便消除了歧义,保证只有一个孩子的节点和叶节点的处理中不存在问题。 (2)Huffman树的调试花了较长时间。Huffman编码本身并不难处理,麻烦的是输入输出。①Huffman编码后的文件是按位存储的,因此需要位运算。 ②文件结尾要刷新缓冲区,这里容易引发边界错误。 在实际编程时,首先编写了屏幕输入输出(用0、1表示二进制位)的版本,然后再加入二进制文件的读写模块。主要调试时间在后者。 二、要让演示版压缩程序具有实用性,哪些地方有待改进? (1)压缩文件的最后一字节问题。 压缩文件的最后一字节不一定对齐到字节边界,因此可能有几个多余的0,而这些多余的0可能恰好构成一个Huffman编码。解码程序无法获知这个编码是否属于源文件的一部分。因此有的文件解压后末尾可能出现一个多余的字节。 解决方案: ①在压缩文件头部写入源文件的总长度(字节数)。需要四个字节来存储这个信息(假定文件长度不超过4GB)。 ②增加第257个字符(在一个字节的0~255之外)用于EOF。对于较长的文件,

会造成较大的损耗。 ③在压缩文件头写入源文件的总长度%256的值,需要一个字节。由于最后一个字节存在或不存在会影响文件总长%256的值,因此可以根据这个值判断整个压缩文件的最后一字节末尾的0是否在源文件中存在。 (2)压缩程序的效率问题。 在编写压缩解压程序时 ①编写了屏幕输入输出的版本 ②将输入输出语句用位运算封装成一次一个字节的文件输入输出版本 ③为提高输入输出效率,减少系统调用次数,增加了8KB的输入输出缓存窗口 这样一来,每写一位二进制位,就要在内部进行两次函数调用。如果将这些代码合并起来,再针对位运算进行一些优化,显然不利于代码的可读性,但对程序的执行速度将有一定提高。 (3)程序界面更加人性化。 Huffman Tree Demo (C) 2011-12-16 boj Usage: huffman [-c file] [-u file] output_file -c Compress file. e.g. huffman -c test.txt test.huff -u Uncompress file. e.g. huffman -u test.huff test.txt 目前的程序提示如上所示。如果要求实用性,可以考虑加入其他人性化的功能。 三、调研常用的压缩算法,对这些算法进行比较分析 (一)无损压缩算法 ①RLE RLE又叫Run Length Encoding,是一个针对无损压缩的非常简单的算法。它用重复字节和重复的次数来简单描述来代替重复的字节。尽管简单并且对于通常的压缩非常低效,但它有的时候却非常有用(例如,JPEG就使用它)。 变体1:重复次数+字符 文本字符串:A A A B B B C C C C D D D D,编码后得到:3 A 3 B 4 C 4 D。

数据结构课程设计报告模板

课程设计说明书 课程名称:数据结构 专业:班级: 姓名:学号: 指导教师:成绩: 完成日期:年月日

任务书 题目:黑白棋系统 设计内容及要求: 1.课程设计任务内容 通过玩家与电脑双方的交替下棋,在一个8行8列的方格中,进行棋子的相互交替翻转。反复循环下棋,最后让双方的棋子填满整个方格。再根据循环遍历方格程序,判断玩家与电脑双方的棋子数。进行大小判断,最红给出胜负的一方。并根据y/n选项,判断是否要进行下一局的游戏。 2.课程设计要求 实现黑白两色棋子的对峙 开发环境:vc++6.0 实现目标: (1)熟悉的运用c语言程序编写代码。 (2)能够理清整个程序的运行过程并绘画流程图 (3)了解如何定义局部变量和整体变量; (4)学会上机调试程序,发现问题,并解决 (5)学习使用C++程序来了解游戏原理。 (6)学习用文档书写程序说明

摘要 本文的研究工作在于利用计算机模拟人脑进行下黑白棋,计算机下棋是人工智能领域中的一个研究热点,多年以来,随着计算机技术和人工智能技术的不断发展,计算机下棋的水平得到了长足的进步 该程序的最终胜负是由棋盘上岗双方的棋子的个数来判断的,多的一方为胜,少的一方为负。所以该程序主要运用的战术有削弱对手行动战术、四角优先战术、在游戏开局和中局时,程序采用削弱对手行动力战术,即尽量减少对手能够落子的位置;在游戏终局时则采用最大贪吃战术,即尽可能多的吃掉对手的棋子;而四角优先战术则是贯穿游戏的始终,棋盘的四角围稳定角,不会被对手吃掉,所以这里是兵家的必争之地,在阻止对手进角的同时,自己却又要努力的进角。 关键词:黑白棋;编程;设计

数据结构课程设计报告

《数据结构与算法》课程设计报告 学号: 班级序号: 姓名: 指导教师: 成绩: 中国地质大学信息工程学院地理信息系统系 2011年12 月

1.需求规格说明 【问题描述】 利用哈夫曼编码进行对已有文件进行重新编码可以大大提高减小文件大小,减少存储空间。但是,这要求在首先对一个现有文件进行编码行成新的文件,也就是压缩。在文件使用时,再对压缩文件进行解压缩,也就是译码,复原原有文件。试为完成此功能,写一个压缩/解压缩软件。 【基本要求】 一个完整的系统应具有以下功能: (1)压缩准备。读取指定被压缩文件,对文件进行分析,建立哈夫曼树,并给出分析结果(包括数据集大小,每个数据的权值,压缩前后文件的大小),在屏幕上输出。 (2)压缩。利用已建好的哈夫曼树,对文件进行编码,并将哈夫曼编码及文件编码后的数据一起写入文件中,形成压缩文件(*.Haf)。 (3)解压缩。打开已有压缩文件(*.Haf),读取其中的哈夫曼编码,构建哈夫曼树,读取其中的数据,进行译码后,写入文件,完成解压缩。 (4)程序使用命令行方式运行 压缩命令:SZip A Test.Haf 1.doc 解压缩命令:SZip X Test.Haf 2.doc或SZip X Test.Haf 用户输入的命令不正确时,给出提示。 (5)使用面向对象的思想编程,压缩/解压缩、哈夫曼构建功能分别构建类实现。 2.总体分析与设计 (1)设计思想: 1、压缩准备:1> 读文件,逐个读取字符,统计频率 2> 建立哈夫曼树 3> 获得哈弗曼编码 2、压缩过程: 1> 建立一个新文件,将储存权值和字符的对象数组取存储在文件头

数据结构课程设计题目选择

数据结构课程设计题目 说明: (1)选用语言:C或Java语言; (2)需要注明3人(可少于3人)小组各自承担和完成的任务(据此给予成绩); (3)如下带“*”的题目,“*”越多,难度越大一些,分值权重更高---要得到更高分数,推荐选择。 要求: (1) 用中文给出设计说明书(含重要子函数的流程图); (2) 给出测试通过、能实现相应功能的源代码; (3) 测试报告。 0、小学数学四则混合运算试题出题、评价、题库自动生成与组卷系统(****)---已经有2组选择 任务: (1)将随机给出的四则混合运算表达式显示在计算机显示器上,要求应试者给出答案;并且使用堆栈对该表达式求值,同给出的答案进行比较,判断 正确和错误。给出鼓励信息和嘉奖信息; (2)保存多人在不同时间应试的题目与他(或她)给出的答案,评价所出题目的难易程度(通过多人回答正确与否的情况给出),形成题库; (3)按照用户给出的题目难易程度指标(例如让50人的得分满足怎样的正态分布,如90分以上10%,80分以上30%,70分以上30%,60分以上20%,60分 以下10%),从题库中抽取不同的题目,组成试卷。 要求:随机产生的题目中,参加运算的数据随机、运算符随机。题目涉及加减乘除,带括弧的混合运算;随时可以退出;保留历史分数,能回顾历史,给出与历史分数比较后的评价。 1、集合的并、交和差运算---已经有1组选择 任务:编制一个能演示执行集合的并、交和差运算的程序。 要求: (1) 集合的元素限定为小写字母字符[…a?..?z?] 。 (2) 演示程序以用户和计算机的对话方式执行。 实现提示:以链表表示集合。 选作内容: (1) 集合的元素判定和子集判定运算。 (2) 求集合的补集。 (3) 集合的混合运算表达式求值。 (4) 集合的元素类型推广到其他类型,甚至任意类型。 2、停车场管理------已经有2组选择 任务:设停车场是一个可以停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次有北向南排列(大门在最南端,最先到达的第一车停放在车场的最北端),若车场内已停满n辆车,那么后来的车只能在门外的便道上等候,一旦有车开走,则排在便道上的第一辆车即可开入;当停车场内某辆车要离开时,在它之后进入的车辆必须先退出车场为它让路,待该辆车开出大门外,其他车辆再按原次序进入车场,每辆停放在车场的车在它离开停车场时必须按它停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。 要求:以栈模拟停车场,以队列模拟车场外的便道。每一组输入数据包括三个数据项:汽车“到达”或“离去”信息、汽车牌照号码以及到达或离去的时刻。对每一组输入数据进行操作后的输出信息为:若是车辆到达,则输出汽车在停车场内或便道上的停车位置;若是车辆离去,则输出汽车在停车场内停留的时间和应交纳的费用(在便道上停车不收费)。栈以顺序存储结构实现,队列以链表结构实现。 3、哈夫曼码的编/译码系统(**)---已经有1组选择

数据结构课程设计独立题目

题目2:运动会分数统计 1.问题描述 参加运动会有n个学校,学校编号为1……n。比赛分成m个男子项目,和w个女子项目。项目编号为男子1……m,女子m+1……m+w。不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或前三名由学生自己设定。(m<=20,n<=20) 2.功能要求 1)可以输入各个项目的前三名或前五名的成绩; 2)能统计各学校总分; 3)可以按学校编号、学校总分、男女团体总分排序输出; 4)可以按学校编号查询学校某个项目的情况;可以按项目编号查询取得前三或前五名的学校。 存储结构:学生自己根据系统功能要求自己设计,但是要求运动会的相关数据要存储在数据文件中。 。 题目6:哈夫曼编/译码器 1.问题描述 利用哈夫曼编码进行信息通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。但是,这要求在发送端通过一个编码系统对待传数据预先编码,在接收端将传来的数据进行译码(复原)。对于双工信道(即可以双向传输信息的信道),每端都需要一个完整的编/译码系统。试为这样的信息收发站写一个哈夫曼编/译码系统。 2.功能要求 I:初始化(Initialization)。从终端读入字符集大小n,以及n个字符和n个权值,建立哈夫曼树,并将它存于文件hfmTree中。 E:编码(Encoding)。利用已建好的哈夫曼树(如不在内存,则从文件htmTree 中读入),对文件ToBeTran中的正文进行编码,然后将结果存入文件CodeFile 中。 D:译码(Decoding)。利用已建好的哈夫曼树将文件CodeFile中的代码进行译码,结果存入文件TextFile中。 P:印代码文件(Print)。将文件CodeFile以紧凑格式显示在终端上,每行50个代码。同时将此字符形式的编码写入文件CodePrint中。 T:印哈夫曼树(Tree Printing)。将已在内存中的哈夫曼树以直观的方式(树或凹入表形式)显示在终端上,同时将此字符形式的哈夫曼树写入文件TreePrint 中。 题目9:构造可以使n个城市连接的最小生成树 1.问题描述 给定一个地区的n个城市间的距离网,用Prim算法或Kruskal算法建立最小生成树,并计算得到的最小生成树的代价。 2.功能要求 城市间的距离网采用邻接矩阵表示,邻接矩阵的存储结构定义采用课本中给出的定义,若两个城市之间不存在道路,则将相应边的权值设为自己定义的无穷大值。要求在屏幕上显示得到的最小生成树中包括了哪些城市间的道路,并显示得到的最小生成树的代价。

数据结构课程设计题目及要求

实验一~实验四任选一题;实验五~实验九任选一题。 实验一运动会分数统计 一、实验目的: (1)熟练掌握线性表的两种存储方式 (2)掌握链表的操作和应用。 (3)掌握指针、结构体的应用 (4)按照不同的学校,不同项目和不同的名次要求,产生各学校的成绩单、团体总分报表。 二、实验内容: 【问题描述】 参加运动会的n个学校编号为1~n。比赛分成m个男子项目和w个女子项目,项目编号分别为1~m和m+1~m+w。由于各项目参加人数差别较大,有些项目取前五名,得分顺序为7,5,3,2,1;还有些项目只取前三名,得分顺序为5,3,2。写一个统计程序产生各种成绩单和得分报表。 【基本要求】 产生各学校的成绩单,内容包括各校所取得的每项成绩的项目号、名次(成绩)、姓名和得分;产生团体总分报表,内容包括校号、男子团体总分、女子团体总分和团体总分。 【测试数据】 对于n=4,m=3,w=2,编号为奇数的项目取前五名,编号为偶数的项目取前三名,设计一组实例数据。 【实现提示】 可以假设m≤20,m≤30,w≤20,姓名长度不超过20个字符。每个项目结束时,将其编号、类型符(区分取前五名还是前三名)输入,并按名次顺序输入运动员姓名、校名(和成绩)。 【选作内容】 允许用户指定某些项目可采取其他名次取法。

实验二停车场管理 一、实验目的: (1)熟练掌握栈顺存和链存两种存储方式。 (2)掌握栈的基本操作及应用。 (3)以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入的输入数据序列进行模拟管理。 二、实验内容: 【问题描述】 设停车场是一个可停放n辆汽车的长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列(大门在最南端,最先到达的第一辆车信放在车场的最北端),若车场内已停满n辆汽车,则后来的汽车只能在门外的便道上等候,一旦有车开走,则排在便道上的第一辆车即可开入;当停车场内某辆车要离开时,在它之后进入的车辆必须先退出车场为它让路,待该辆车开出大门外,其他车辆再按原次序进入车场院,每辆停放在车场的车在它离开停车场时必须按它停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。 【基本要求】 以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入的输入数据序列进行模拟管理。每一组输入数据包括三个数据项:汽车“到达”或“离去”信息、汽车牌照号码以及到达或离去的时刻。对每一组输入数据进行操作后的输出信息为:若是车辆到达,则输出汽车在停车场内或便道上的停车位置;若是车辆离去,则输出汽车在停车场内停留的时间和应交纳的费用(在便道上停留的时间不收费)。栈以顺序结构实现,队列以链表结构实现。 【测试数据】 设n=2,输入数据为:(A,1,5),(A,1,15),(A,3,20),(A,4,25),(A,5,30),(D,2,35),(D,4,40),(E,0,0)。其中:A表示到达(Arrival);D表示离去(Departure);E表示输入结束(End)。 【实现提示】 需另设一个栈,临时停放为给要离去的汽车让路而从停车场退出来的汽车,也用顺序存储结构实现。输入数据按到达或离去的时刻有序。栈中每个元素表示一辆汽车,包含两个数据项:汽车的牌照号码和进入停车场的时刻。 【选作内容】 (1)两个栈共享空间,思考应开辟数组的空间是多少? (2)汽车可有不同种类,则他们的占地面积不同收费标准也不同,如1辆客车和1.5辆小汽车的占地面积相同,1辆十轮卡车占地面积相当于3辆小汽车的占地面积。(3)汽车可以直接从便道开走,此时排在它前面的汽车要先开走让路,然后再依次排到队尾。 (4)停放在便道上的汽车也收费,收费标准比停放在停车场的车低,请思考如何修改结构以满足这种要求。

数据结构课程设计题目

《数据结构》课程设计题目 1. 排序算法的性能分析 问题描述 设计一个测试程序,比较几种内部排序算法的关键字比较次数和移动次数以取得直观感受。 基本要求 (1)对冒泡排序、直接排序、选择排序、箱子排序、堆排序、快速排序及归并排序算法进行比较。 (2)待排序表的表长不小于100,表中数据随机产生,至少用5组不同数据作比较,比较指标:关键字参加比较次数和关键字的移动次数(关键字交换记为3次移动)。 (3)输出比较结果。 选做内容 (1)对不同表长进行比较。 (2)验证各算法的稳定性。 (3)输出界面的优化。 2. 排序算法思想的可视化演示—1 基本要求 排序数据随机产生,针对随机案例,对冒泡排序、箱子排序、堆排序、归并算法,提供排序执行过程的动态图形演示。 3. 排序算法思想的可视化演示—2 基本要求 排序数据随机产生,针对随机案例,,对插入排序、选择排序、基数排序、快速排序算法,提供排序执行过程的动态图形演示。 4. 线性表的实现与分析 基本要求 ①设计并实现线性表。 ②线性表分别采取数组(公式化描述)、单链表、双向链表、间接寻址存储方 式 ③针对随机产生的线性表实例,实现线性表的插入、删除、搜索操作动态演示(图 形演示)。 5. 等价类实现及其应用 问题描述:某工厂有一台机器能够执行n个任务,任务i的释放时间为r i(是一个整数),最后期限为d i(也是整数)。在该机上完成每个任务都需要一个单元的时间。一种可行的调

度方案是为每个任务分配相应的时间段,使得任务i的时间段正好位于释放时间和最后期限之间。一个时间段不允许分配给多个任务。 基本要求: 使用等价类实现以上机器调度问题。 等价类分别采取两种数据结构实现。 6. 一元稀疏多项式计算器 问题描述 设计一个一元稀疏多项式简单计算器。 基本要求 一元稀疏多项式简单计算器的基本功能是: (1)输入并建立多项式; (2)输出多项式,输出形式为整数序列:n,c1,e1,c2,e2,…,c n,e n,其中n是多项式的项数,c i,e i,分别是第i项的系数和指数,序列按指数降序排序; (3)多项式a和b相加,建立多项式a+b; (4)多项式a和b相减,建立多项式a-b; (5)计算多项式在x处的值; (6)计算器的仿真界面(选做) 7. 长整数的代数计算 问题描述 应用线性数据结构解决长整数的计算问题。设计数据结构完成长整数的表示和存储,并编写算法来实现两长整数的加、减、乘、除等基本代数运算。 基本要求 ①长整数长度在一百位以上。 ②实现两长整数在取余操作下的加、减、乘、除操作,即实现算法来求解a+b mod n, a-b mod n, a?b mod n, a÷b mod n。 ③输入输出均在文件中。 ④分析算法的时空复杂性。 8. 敢死队问题。 有M个敢死队员要炸掉敌人的一碉堡,谁都不想去,排长决定用轮回数数的办法来决定哪个战士去执行任务。如果前一个战士没完成任务,则要再派一个战士上去。现给每个战士编一个号,大家围坐成一圈,随便从某一个战士开始计数,当数到5时,对应的战士就去执行任务,且此战士不再参加下一轮计数。如果此战士没完成任务,再从下一个战士开始数数,被数到第5时,此战士接着去执行任务。以此类推,直到任务完成为止。排长是不愿意去的,假设排长为1号,请你设计一程序,求出从第几号战士开始计数才能让排长最后一个留下来而不去执行任务。 要求:至少采用两种不同的数据结构的方法实现。 9. 简单计算器

数据结构课程设计报告

《数据结构课程设计》报告 题目:课程设计题目2教学计划编制 班级:700 学号:09070026 姓名:尹煜 完成日期:2011年11月7日

一.需求分析 本课设的任务是根据课程之间的先后的顺序,利用拓扑排序算法,设计出教学计划,在七个学期中合理安排所需修的所有课程。 (一)输入形式:文件 文件中存储课程信息,包括课程名称、课程属性、课程学分以及课程之间先修关系。 格式:第一行给出课程数量。大于等于0的整形,无上限。 之后每行按如下格式“高等数学公共基础必修6.0”将每门课程的具体信息存入文件。 课程基本信息存储完毕后,接着给出各门课程之间的关系,把每门课程看成顶点,则关系即为边。 先给出边的数量。大于等于0的整形。 默认课程编号从0开始依次增加。之后每行按如下格式“1 3”存储。此例即为编号为1的课程与编号为3的课程之间有一条边,而1为3的前驱,即修完1课程才能修3课程。 例: (二)输出形式:1.以图形方式显示有向无环图

2.以文本文件形式存储课程安排 (三)课设的功能 1.根据文本文件中存储的课程信息(课程名称、课程属性、课程学分、课程之间关系) 以图形方式输出课程的有向无环图。 拓展:其显示的有向无环图可进行拖拽、拉伸、修改课程名称等操作。 2.对课程进行拓扑排序。 3.根据拓扑排序结果以及课程的学分安排七个学期的课程。 4.安排好的教学计划可以按图形方式显示也可存储在文本文件里供用户查看。 5.点击信息菜单项可显示本人的学好及姓名“09070026 尹煜” (四)测试数据(见六测设结果)

二.概要设计 数据类型的定义: 1.Class Graph即图类采用邻接矩阵的存储结构。类中定义两个二维数组int[][] matrix 和Object[][] adjMat。第一个用来标记两个顶点之间是否有边,为画图服务。第二个 是为了实现核心算法拓扑排序。 2.ArrayList list用来存储课程信息。DrawInfo类是一个辅助画图的类,其中 包括成员变量num、name、shuxing、xuefen分别代表课程的编号、名称、属性、 学分。ArrayList是一个DrawInfo类型的数组,主要用来在ReadFile、DrawG、DrawC、SaveFile、Window这些类之间辅助参数传递,传递课程信息。 3.Class DrawInfo, 包括int num;String name;String shuxing;float xuefen;四个成员变量。 4.Class Edge包括int from;int to;double weight;三个成员变量。 5.Class Vertex包括int value一个成员变量。 主要程序的流程图: //ReadFile.java

数据结构课程设计报告

编号 课程设计 题目 1、一元稀疏多项式计算器 2、模拟浏览器操作程序 3、背包问题的求解 4、八皇后问题 二级学院计算机科学与工程学院 专业计算机科学与技术 班级 2011级 37-3班 学生姓名 XX 学号 XXXXXXXXXX 指导教师 XXXXX 评阅教师 时间 1、一元稀疏多项式计算器 【实验内容】 一元稀疏多项式计算器。

【问题描述】 设计一个一元稀疏多项式简单计算器。 【需求分析】 其基本功能包括: (1)输入并建立多项式; (2)输出多项式,输出形式为整数序列为:n,c1,e1,c2,e2,……,cn,en,其中n 是多项式的项数,ci,ei分别是第i项的系数和指数,序列按指数降序排序;(3)多项式a和b相减,建立多项a+b; (4)多项式a和b相减,建立多项式a-b; (5)计算多项式在x处的值; (6)计算器的仿真界面(选做); 【概要设计】 -=ADT=- { void input(Jd *ha,Jd *hb); void sort(dnode *h)

dnode *operate(dnode *a,dnode *b) float qiuzhi(int x,dnode *h) f",sum); printf("\n"); } 【运行结果及分析】 (1)输入多项式:

(2)输出多项式(多项式格式为:c1x^e1+c2x^e2+…+cnx^en): (3)实现多项式a和b相加: (4)实现多项式a和b相减: (5)计算多项式在x处的值:

2、模拟浏览器操作程序 【实验内容】 模拟浏览器操作程序 【问题描述】 标准Web浏览器具有在最近访问的网页间后退和前进的功能。实现这些功能的一个方法是:使用两个栈,追踪可以后退和前进而能够到达的网页。在本题中,要求模拟实现这一功能。 【需求分析】 需要支持以下指令: BACK:将当前页推到“前进栈”的顶部。取出“后退栈”中顶端的页面,使它成为当前页。若“后退栈”是空的,忽略该命令。 FORWARD:将当前页推到“后退栈”的顶部。取出“前进栈”中顶部的页面,使它成为当前页。如果“前进栈”是空的,忽略该命令。 VISIT:将当前页推到“后退栈”的顶部。使URL特指当前页。清空“前进栈”。 QUIT:退出浏览器。 假设浏览器首先加载的网页URL是:http:

数据结构课程设计题目表

《数据结构》课程设计课题表 课题1:设计出链表结构的相关函数库,以便在程序设计中调用。要求: (1)包括线性表的各种基本函数以及常用函数(自己确定函数、函数形式及理由)。 (2)最好能借助语言环境实现图形显示功能,以便能将抽象的数据结构以图形方式显示出来,将复杂的运行过程以动态方式显示出来。 (3)给出若干例程,演示通过调用自己的库函数来实现相关问题的求解。 课题2:设计出顺序表结构的相关函数库,以便在程序设计中调用。要求: (1)包括线性表的各种基本函数以及常用函数(自己确定函数、函数形式及理由)。 (2)最好能借助语言环境实现图形显示功能,以便能将抽象的数据结构以图形方式显示出来,将复杂的运行过程以动态方式显示出来。 (3)给出若干例程,演示通过调用自己的库函数来实现相关问题的求解。 课题3:设计程序以实现任意两个高次多项式的加法和乘法运算。 要求: (1)所设计的数据结构应尽可能节省存储空间。 (2)程序的运行时间应尽可能少。 课题4:设计一个模拟计算器的程序,要求能对包含加、减、乘、除、括号运算符及SQR和ABS函数的任意整型表达式进行求解。 要求:要检查有关运算的条件,并对错误的条件产生报警。 课题5:设计出二叉链表结构的相关函数库,以便在程序设计中调用。要求: (1)包括二叉树的各种基本函数以及常用函数(自己确定函数、函数形式及理由)。 (2)最好能借助语言环境实现图形显示功能,以便能将抽象的数据结构以图形方式显示出来,将复杂的运行过程以动态方式显示出来。 (3)给出若干例程,演示通过调用自己的库函数来实现相关问题的求解。 课题6:设计出树结构的相关函数库,以便在程序设计中调用。要求: (1)包括树结构的存储结构及各种基本函数以及常用函数(自己确定函数、函数形式及理由)。 (2)最好能借助语言环境实现图形显示功能,以便能将抽象的数据结构以图形方式显示出来,将复杂的运行过程以动态方式显示出来。 (3)给出若干例程,演示通过调用自己的库函数来实现相关问题的求解。 课题7:选择合适的存储结构表示广义表,并能实现下列运算要求: (1)用大写字母表示广义表,用小写字母表示原子,并提供设置广义表的值的功能。 (2)取广义表L的表头和表尾的函数head(L)和tail(L)。

数据结构课程设计

《数据结构》 课程设计报告 学号 姓名 班级 指导教师 安徽工业大学计算机学院 2010年6月

建立二叉树和线索二叉树 1.问题描述: 分别用以下方法建立二叉树并用图形显示出来: 1)用先序遍历的输入序列 2)用层次遍历的输入序列 3)用先序和中序遍历的结果 2.设计思路: 分三个方式去实现这个程序的功能,第一个实现先序遍历的输入数列建立二叉树;第二个是用层次遍历的方法输入序列;第三个是用先序和后序遍历的结果来建立二叉树;三种方法建立二叉树后都进行输出。关键是将这三个实现功能的函数写出来就行了;最后对所建立的二叉树进行中序线索化,并对此线索树进行中序遍历(不使用栈)。 3.数据结构设计: 该程序的主要目的就是建立二叉树和线索二叉树,所以采用树的存储方式更能完成这个程序; 结点的结构如下: typedef struct bnode { DataType data; int ltag,rtag; struct bnode *lchild, *rchild; } Bnode, *BTree; 4.功能函数设计: BTree CreateBinTree() 用先序遍历的方法讲二叉树建立; BTree CREATREE() 用队列实现层次二叉树的创建; void CreatBT(); 用先序和中序遍历的结果建立二叉树; void InThread(BTree t,BTree pre) 中序线索化; 5.编码实现: #include #include #define max 100 typedef struct bnode { char data; int ltag,rtag; struct bnode *lchild,*rchild; }Bnode,*BTree; BTree Q[max]; BTree CREATREE() { char ch; int front=1,rear=0;

数据结构课程设计报告

数据结构课程设计 设计说明书 TSP 问题 起止日期:2016 年 6 月27 日至2016 年7 月 1 日 学生姓名 班级 学号 成绩 指导教师( 签字) 2016 年7 月 1 日

目录 第1 章需求分析.................................................................................1... 1.1 简介 (1) 1.2 系统的开发背景 (1) 1.3 研究现状 (1) 第2 章概要设计.................................................................................2... 2.1 系统开发环境和技术介绍 (2) 2.2 系统需求分析 (2) 2.2.1 总体功能分析 (2) 2.2.2 核心功能分析 (3) 第3 章详细设计...................................................................................4... 3.1 系统开发流程 (4) 3.2 系统模块设计 (4) 3.3 系统结构 (6) 3.2 系统流程图 (6) 第4 章调试分析...................................................................................7... 4.1 程序逻辑调试 (7) 4.2 系统界面调试 (8) 第5 章测试结果...................................................................................9... 5.1 测试环境 (9) 5.2 输入输出测试项目 (9) 5.3 测试结果 (10) 结论.....................................................................................................1..1.. 参考文献................................................................................................1..1. 附录.......................................................................................................1..2..

关于数据结构课程设计心得体会范文

关于数据结构课程设计心得体会范文 心得体会是指一种读书、实践后所写的感受性文字。是指将学习的东西运用到实践中去,通过实践反思学习内容并记录下来的文字,近似于经验总结。下面是小编搜集的关于数据结构课程设计心得体会范文,希望对你有所帮助。 关于数据结构课程设计心得体会(1) 这学期开始两周时间是我们自己选题上机的时间,这学期开始两周时间是我们自己选题上机的时间,虽然上机时间只有短短两个星期但从中确实学到了不少知识。上机时间只有短短两个星期但从中确实学到了不少知识。 数据结构可以说是计算机里一门基础课程,据结构可以说是计算机里一门基础课程,但我觉得我们一低计算机里一门基础课程定要把基础学扎实,定要把基础学扎实,然而这次短短的上机帮我又重新巩固了 c 语言知识,让我的水平又一部的提高。数据结构这是一门语言知识让我的水平又一部的提高。数据结构这是一门知识,纯属于设计的科目,它需用把理论变为上机调试。 纯属于设计的科目,它需用把理论变为上机调试。它对我们来说具有一定的难度。它是其它编程语言的一门基本学科。来说具有一定的难度。它是其它编程语言的一门基本学科。我选的上机题目是交叉合并两个链表,对这个题目,我选的上机题目是交叉合并两个链表,对这个题目,我觉得很基础。刚开始调试代码的时候有时就是一个很小的错觉得很基础。 刚开始调试代码的时候有时就是一个很小的错调试代码的时候误,导致整个程序不能运行,然而开始的我还没从暑假的状导致整个程序不能运行,态转到学习上,每当程序错误时我都非常焦躁,态转到学习上,每当程序错误时我都非常焦躁,甚至想到了放弃,但我最终找到了状态,一步一步慢慢来,放弃,但我最终找到了状态,一步一步慢慢来,经过无数次的检查程序错误的原因后慢慢懂得了耐心是一个人成功的必然具备的条件! 同时,通过此次课程设计使我了解到,必然具备的条件! 同时,通过此次课程设计使我了解到,硬件语言必不可缺少,要想成为一个有能力的人,必须懂得件语言必不可缺少,要想成为一个有能力的人,硬件

数据结构课程设计题目

数据结构课程设计 一、考核方法和容 根据课程设计过程中学生的学生态度、题目完成情况、课程设计报告书的质量和回答问题的情况等按照10%、40%、30%、20%加权综合打分。成绩评定实行优秀、良好、中等、及格和不及格五个等级。 评分标准: 优秀:答辩所有问题都能答出+报告良好 或报告良好+实现“提高部分”的功能; 良好:答辩所有问题都能答出+报告一般; 或报告一般+实现“提高部分”的功能; 中等:答辩大部分问题能答出+报告良好; 及格:答辩大部分问题能答出+报告一般; 以下四种,都不及格: 1)答辩几乎答不出问题; 2)报告几乎都是代码; 3)雷同部分达到60%; 4)课设报告与数据结构和c/c++关联不大。 课设报告的装订顺序如下: 任务书(签名,把题目要求贴在相应位置,注意下划线)-----目录(注意目录的格式,页码)-----1、设计任务(题目要求)-----2、需求分析(准备选用什么数据逻辑结构?数据元素包含哪些属性?需要哪些函数?为什么要这样设计?最后列出抽象数据类型定义)-----3、系统设计(设计实现抽象数据类型,包含选择什么物理存储方式?数据元素的结构体或类定义,以及各函数的设计思路,算法,程序流程图等)----4、编码实现(重要函数的实现代码)-----5、调试分析(选择多组测试数据、运行截图、结果分析)-----6、课设总结(心得体会)-----7、谢辞-----8、参考文献; 课设报告打印要求: B5纸打印,报告总页数控制在10—15页,报告中不能全是代码,报告中代码总量控制在3页。版式:无页眉,有页码,页码居中 字号:小四,单倍行距 字体:宋体+Times new Romar 截图:截图要配图的编号和图的题目,如:“图1 Insert函数流程图” 二、课程设计的题目 1.长整数的加法运算 2.通讯录管理系统的设计与实现——顺序表 3.广义表的应用 4.学生成绩管理系统的设计与实现 5.家谱管理系统的设计与实现

数据结构课程设计

一、高校社团管理 在高校中,为了丰富学生的业余生活,在学校的帮助下,会成立许多社团,少则几个,多则几十个。为了有效管理这些社团,要求编写程序实现以下功能:1.社团招收新成员; 2.修改社团相应信息 3.老成员离开社团 4.查询社团情况; 5.统计社团成员数; 二、简单文本编辑器 设计一个文本编辑器,允许将文件读到内存中,也就是存储在一个缓冲区中。这个缓冲区将作为一个类的内嵌对象实现。缓冲区中的每行文本是一个字符串,将每行存储在一个双向链表的结点中,要求设计在缓冲区中的行上执行操作和在单个行中的字符上执行字符串操作的编辑命令。 基本要求: 包含如下命令列。可用大写或小写字母输入。 R:读取文本文件到缓冲区中,缓冲区中以前的任何内容将丢失,当前行是文件的第一行; W:将缓冲区的内容写入文本文件,当前行或缓冲区均不改变。 I:插入单个新行,用户必须在恰当的提示符的响应中键入新行并提供其行号。 D:删除当前行并移到下一行; F:可以从第1行开始或从当前行开始,查找包含有用户请求的目标串的第一行; C:将用户请求的字符串修改成用户请求的替换文本,可选择是仅在当前行中有效的还是对全文有效的。 Q:退出编辑器,立即结束; H:显示解释所有命令的帮助消息,程序也接受?作为H的替代者。 N:当前行移到下一行,也就是移到缓冲区的下一行; P:当前行移到上一行,也就是移到缓冲区的上一行;

B:当前行移到开始处,也就是移到缓冲区的第一行; E:当前行移到结束处,也就是移到缓冲区的最后一行; G:当前行移到缓冲区中用户指定的行; V:查看缓冲区的全部内容,打印到终端上。 三、电话客户服务模拟 一个模拟时钟提供接听电话服务的时间(以分钟计),然后这个时钟将循环的 自增1(分钟)直到达到指定时间为止。在时钟的每个"时刻",就会执行一次检查来看看对当前电话服务是否已经完成了,如果是,这个电话从电话队列中删除,模 拟服务将从队列中取出下一个电话(如果有的话)继续开始。同时还需要执行一个检查来判断是否有一个新的电话到达。如果是,其到达时间被记录下来,并为其产生一个随机服务时间,这个服务时间也被记录下来,然后这个电话被放入电话队列中,当客户人员空闲时,按照先来先服务的方式处理这个队列。当时钟到达指定时间时,不会再接听新电话,但是服务将继续,直到队列中所偶电话都得到处理为止。 基本要求: (1)程序需要的初始数据包括:客户服务人员的人数,时间限制,电话的到达速率,平均服务时间 (2)程序产生的结果包括:处理的电话数,每个电话的平均等待时间 四、停车场管理 设停车场是一个可停放n辆车的狭长通道,且只有一个大门可供汽车进出。在停车场内,汽车按到达的先后次序,由北向南依次排列(假设大门在最南端)。若停车场内已停满n辆车,则后来的汽车需在门外的便道上等候,当有车开走时,便道上的第一辆车即可开入。当停车场内某辆车要离开时,在它之后进入的车辆必须先退出停车场为它让路,待该辆车开出大门后,其他车辆再按原次序返回车场。每辆车离开停车场时,应按其停留时间的交费(从进入便道开始计时)。在这里假设汽车从便道上开走时不收取任何费用 基本要求: (1)汽车的输入信息格式为(到达/离去的标识,汽车牌照号码,到达/离去的时间)

相关文档
相关文档 最新文档