第3章 顺序存储结构的表、堆栈和队列汇.ppt

第3章 顺序存储结构的表、堆栈和队列汇.ppt

  1. 1、本文档共127页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第3章 顺序存储结构的表、堆栈和队列汇

第3章 顺序存储结构的表、堆栈和队列 3.1 顺序存储结构 3.2 表和顺序表 ? 3.3 堆栈和顺序堆栈 3.4 队列和顺序队列 3.5 优先级队列和顺序优先级队列 3.1 顺序存储结构 计算机所处理的所有的数据都要存储在内存中。计算机高级语言系统对数据的存储结构有四种:顺序存储结构、链式存储结构、间接地址和仿真指针。其中,顺序存储结构和链式存储结构是两种最基本和最常用的存储结构。本节讨论顺序存储结构,其余三种存储结构依次在4.1节、5.2节和7.1节中讨论。 顺序存储结构是计算机中的一种最基本和最主要的数据存储结构。在顺序存储结构中,用户向系统申请一块地址连续的有限空间用于存储数据元素集合,这样,任意两个在逻辑上相邻的数据元素在物理上也必然相邻。在C++中,向系统申请一块地址连续的有限空间的方法是使用数组。数组有静态数组和动态数组两种。不论是静态数组还是动态数组,其功能都是向系统申请一块地址连续的有限空间,只是使用的方法不同。 C++中静态数组向系统申请一块地址连续的有限空间的方法是使用数组定义语句“[]”。当程序运行超出该静态数组定义的范围时,系统自动回收该静态数组的地址空间。一个静态数组定义的例子如下: #includestdio.h const int MaxSize=100; void main(void) { int i; int temp[MaxSize]; //静态申请MaxSize个整型元素的存储空间 for(i=0;i6;i++) { temp[i]=i+1; printf(temp[%d]=%d\n,i,temp[i]); //C函数输出 } } 当程序运行退出主函数时,系统将自动回收分配给静态数组temp的地址空间。 C++中动态数组向系统申请一块地址连续的有限空间的方法是使用动态存储分配函数。动态数组存储空间的回收方法是当不再需要该动态数组时,使用动态存储释放函数。C++中动态存储分配函数用new,动态存储释放函数用delete。new能自动计算要分配类型的空间大小并自动返回正确的指针类型。delete能自动释放由new分配的存储空间。 new的语法格式是:名字指针=new类型名(初始化值)。其中,初始化值可为空。 new分配动态数组的语法格式是:名字指针=new类型名[N]。其中,N必须是有确定值的整数型常量或变量。 delete的语法格式是:delete名字指针 delete释放动态数组的语法格式是:delete[]名字指针上例的动态数组定义的例子如下: #includeiostream.h #includestdlib.h void main(void) { int i,*temp; const int MaxSize=100; temp=new int[MaxSize]; //动态申请MaxSize个整型元素的存储空间 for(i=0;i6;i++) { temp[i]=i+1; //动态数组测试 couti=itemp[i]=temp[i]endl; } delete[ ]temp;//释放申请的动态存储空间 } 从上例可见,静态数组存储空间的申请和释放由系统自动完成,动态数组存储空间的申请和释放由用户通过调用系统函数完成。 设要存储的数据元素为a0,a1,a2,a3,a4,a5,顺序存储结构(不论是用静态数组还是用动态数组)向系统申请了MaxSize个ai数据类型的存储空间,size为数

文档评论(0)

liwenhua00 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档