ImageVerifierCode 换一换
格式:DOCX , 页数:41 ,大小:232.85KB ,
资源ID:1140941      下载积分:10 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-1140941.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构实验报告(数据结构与算法).docx)为本站会员(文****钱)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

数据结构实验报告(数据结构与算法).docx

1、- 0 -数据结构实验报告实验名称 数据结构与算法专业班级 数学与应用数学 1201 班学 号 1304120306姓 名 谢 伟指导老师 陈 明- 1 -目 录1 前言.22 数据结构与算法实验概要.22.1 实验要求22.2 主要仪器设备.22.3 实验内容与简介23 数据结构设计与算法设计.33.1 线性表的操作 .33.2 二叉树的操作 .83.3 图的遍历操作 .123.4 栈的基本操作 .193.5 哈希表设计 .284 实验总结与心得体会.395 参考文献. 40- 2 -1 前言数据结构是计算机程序设计的重要理论技术基础,它不仅是计算机学科的核心课程,而且已经成为其他理工专业的

2、热门选修课。随着计算机科学的技术和发展,计算机的功能和运算速度不断地提高,其应用于信息处理的范围日益扩大。与之相应的,计算机的加工处理对象也从简单的数据发展到一般的符号,进而发展到更复杂的数据结构。数据结构是计算机程序设计的重要理论技术基础,数据结构的表示和操作都涉及到算法,如何描述数据的结构和讨论有关的算法,又涉及到程序设计语言。因此,它不仅是计算机学科的核心课程,而且已经成为其他理工专业的热门选修课。 我们通过对这门基础课程的学习,要学会分析研究计算机加工的数据结构的特性,以便为应用涉及的数据选择适合的逻辑结构,储存结构及其相应的算法,并初步掌握算法时间分析和空间分析的技术。通过实际操作去

3、了解数据结构原理, 练习编写代码的能力,以及抽象能力。从课程性质上讲, “数据结构”是一门专业技术基础课。它的要求是学会分析研究计算机加工的数据结构的特性,以便为应用涉及的数据选择适当的逻辑结构,存储结构及相应的算法,并初步掌握算法的时间分析和空间分析的技术。另一方面,数据结构的学习过程也是复杂程序设计的训练过程,要求编 写的程序结构清楚和正确易读,符合软件工程的规范。2 数据结构与算法实验概要2.1 实验要求书写类 C 语言的算法,并将算法转变为程序实现。正确理解各种数据结构的逻辑特性和存储表示和基本操作的算法实现。针对问题的不同选择合适的数据结构,提高算法设计的能力和动手实验的技能。2.2

4、 实验仪器设备硬件要求:在多媒体教室讲解及演示。为保证教学顺利进行,要求实验室提供- 3 -P及以上的微机。2.3 实验项目内容简介1、线性表基本操作 (1 ) 熟悉线性表的基本运算在两种存储结构(顺序结构和链式结构)上的实现(2 )以线性表的各种操作(建立、插入、删除等)的实现为重点(3 ) 通过本次实习帮助学生加深对 c+的使用(特别是函数参数、指针类型、链表的使用) 。2、栈、队列以及递归算法的设计(1 )掌握栈和队列这两种特殊的线性表,熟悉它们的特性,在实际问题背景下灵活运用它们(2 )训练的要点是“栈”的观点及其典型用法;问题求解的状态表示及其递归算法;由递归程序到非递归程序的转化方

5、法3、树、图及其应用 (1 ) 树和图是两种非线性数据结构,广义表的实质是树结构,而稀疏矩阵的十字链表存储结构也是图的一种存储结构,故本单元是本课的实习重点。(2 ) 要求我们熟悉各种存储结构的特性,以及如何应用树和图结构求解具体问题。(3 )训练的要点是:递归算法的设计方法;表达式的求值技术;哈夫曼方法及其编译码技术;完整的应用系统的用户界面设计和操作定义方法;矩阵乘法的特殊操作顺序;路径遍历(树、图的遍历)技术。4、查找和排序本次实习旨在集中对几个专门的问题做较为深入的探讨和理解重点在掌握各种内部排序算法、查找算法的思想和实现。学生在实习中体会查找和内部排序算法思想,理解开发高效算法的可能

6、性和寻找、构造高效算法的方法。3 数据结构设计与算法设计3.1 线性表的操作3.1.1 实验目的1熟悉 C+语言的上机环境,掌握 C+语言的基本结构。2会定义线性表的顺序存储结构。 (链式存储结构)3熟悉对顺序表(单链表)的一些基本操作。- 4 -3.1.2 实验内容单链表的基础操作 包括: 查找、插入、删除、创建链表等。源程序代码:#include #include typedef struct Node int data; struct Node *next; Node; Node *Serach(Node *pHead,int x) Node *p=pHead; while(p!=NUL

7、L return p; void Insert(Node *p,int x) Node *s; s=(Node*)malloc(sizeof(Node); s-data=x; s-next=p-next; p-next=s; void DeleteFollowNode(Node *p) Node *q; q=p-next; - 5 -if(q!=NULL) p-next=q-next; free(q); void Delete(Node *p,Node *pHead) if (p=NULL) return; Node *qPre=pHead; while(qPre!=NULL if (qPre

8、!=NULL free(p); Node* CreateListAhead(int a,int n) Node *s,*pHead; int i; pHead=(Node*)malloc(sizeof(Node); pHead-data=0; - 6 -pHead-next=NULL;for(i=n-1;i=0;i-) s=(Node*)malloc(sizeof(Node); s-data=ai; s-next=pHead-next; pHead-next=s; return pHead; Node* CreateListTail(int a,int n) Node *s,*pHead,*p

9、Tail; int i; pHead=(Node*)malloc(sizeof(Node); pHead-data=0; pHead-next=NULL;pTail=pHead; for(i=0;idata=ai; s-next=NULL; pTail-next=s; pTail=s; return pHead; void Print(Node *h) - 7 - Node *p; p=h-next; while(p!=NULL) printf(“%d,“,p-data); p=p-next; printf(“n“); void main() int a=3,2,1,4,5; Node *pH

10、ead,*p; pHead=CreateListTail(a,5); Print(pHead); p=Serach(pHead,4); printf(“%dn“,p-data); p=pHead-next-next; Insert(p,9); Print(pHead); p=pHead-next-next-next; Delete(p,pHead); Print(pHead); - 8 -while(getchar()!=a) ; 运行结果:3.2 二叉树的操作3.2.1 实验目的理解并熟悉掌握创建二叉树和实现二叉树的三种遍历3.2.2 实验内容创建二叉树并实现二叉树的三中遍历操作源程序代码:

11、#include#include #include typedef int DataType; typedef struct Node- 9 -DataType data;struct Node *LChild;struct Node *RChild;BitNode,*BitTree;void CreatBiTree(BitTree *bt)/用扩展先序遍历序列创建二叉树,如果是#当前树根置为空,否则申请一个新节点/char ch;ch=getchar();if(ch=.)*bt=NULL;else*bt=(BitTree)malloc(sizeof(BitNode);(*bt)-data=ch;CreatBiTree(CreatBiTree(void Visit(char ch)/访问根节点printf(“%c “,ch);void PreOrder(BitTree root) /*先序遍历二叉树, root 为指向二叉树 (或某一子树)根结点的指针*/if (root!=NULL)Visit(root -data); /*访问根结点*/PreOrder(root -LChild); /*先序遍历左子树*/PreOrder(root -RChild); /*先序遍历右子树*/

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。