系統结构与算法分析实验报告.docxVIP

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
系統结构与算法分析实验报告

数据结构与算法分析上机实验报告班级:姓名:学号:实验内容:(1)、针对线性表或栈或队列(任选一种),编程实现选择顺序或链式(任选一种)存储结构下数据结构建立、元素插入、删除等基本操作,并演示实际例子运行结果。(2)、编程实现二叉搜索树的建立、中序遍历、元素查找等功能,并演示实际例子的运行结果。二、算法:(1)、线性表的实现应用自定义结构体SqList,,包含了顺序表的数据成员。数据成员包括*elem;length;listsize. (2)、二叉搜索树结点为binNode.binNode类是带有参数T的模板,成员函数的功能包括设置或返回元素的值、返回左右结点的指针。bst是二叉搜索树,成员函数包括构造函数、析构函数、插入元素、删除元素、中序遍历等。三、源代码:(1)#include iostreamusing namespace std;#define LIST_INIT_SIZE 100#define LISTINCREMENT 10typedefintElemType;typedefint Status;#define OK 1#define OVERFLOW -1#define ERROR -2typedefstruct{ElemType *elem;int length;intlistsize;}SqList;Status Initlist_Sq(SqList L)//线性表初始化{L.elem=(ElemType * )malloc(LIST_INIT_SIZE*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW);L.length =0;L.listsize=LIST_INIT_SIZE; return OK;}Status Put(SqList L,int n)//输入操作{cout输入这n个数据:endl; for(inti=0;in;i++)cinL.elem[i];L.length =L.length +n; return OK;} Status Out(SqList L,int n)//输出操作{ for(inti=0;in;i++)coutL.elem[i] ;coutendl; return OK;}int *p,*q,*e;Status ListInsert_Sq(SqList L,inti,ElemType e)//插入操作{ElemType *newbase; if(i1||iL.length+1) return ERROR; if(L.length =L.listsize){ newbase=(ElemType*)realloc(L.elem, (L.listsize+LISTINCREMENT)*sizeof(ElemType)); if(!newbase)exit(OVERFLOW);L.elem=newbase;L.listsize+=LISTINCREMENT;}q=(L.elem[i-1]);for(p=(L.elem[L.length-1]);p=q;--p) *(p+1)=*p;*q=e;++L.length;return OK;}Status ListDelete_Sq(SqList L,inti,ElemType e)//删除操作{if((i1)||(i=L.length)) return ERROR;p=(L.elem[i-1]);e=*p;q=L.elem+L.length-1;for (++p;p=q;++p) *(p-1)=*p;--L.length;return OK;}intLocateElem_Sq(SqListL,ElemType f)//搜索操作{inti=1; p=L.elem; while((i=L.length)!((*p++)==f)) i++; if(i=L.length) return i; else return 0;}int main(){intn,i,k,e,j,f;SqList La;Initlist_Sq(La);cout数据个数n:endl;cinn; Put(La,n);cout线性表:endl; Out(La,n);cout插入操作,请依次输入插入位置i,插入数据k:endl;cinik;ListInsert_Sq(La,i,k);cout插入后的线性表:endl; Out(La,La.length);cout删除操作,请输入删除位置j:endl;cinj;ListDelete_Sq(La,j,e);cout删除之后的线性表:endl; Out(La,La.length);cout删除的数据e是eendl;cou

文档评论(0)

df9v4fzI + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档