- 1、本文档共51页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构(三)04659
顺序存储队列的类型定义: parameter (MAXLEN=4) structure queuetype datatype q(MAXLEN) integer front integer rear end structure #define MAXSIZE 4 Typedef struct { datatype *data; int front; int rear; } SeqQueue (b) 循环队列 rear front 1 2 3 4 (3) 队空 队满条件: mod(rear,maxlen)+1.eq.front (rear%MAXSIZE)+1 == front 注:实际上为了避免与队空标志冲突,还留有一个空间。 通过加入取余运算,将头尾连接成一个环,形成循环队列。 rear (1)一般情况 front 1 2 3 4 e4 e3 (2) 队满 front e3 e4 1 2 3 4 rear e5 队空条件: front .eq. rear front==rear 循环队列的初始化(置空队)算法: subroutine InitlQueue(sq) parameter (MAXLEN=4) 结构体类型queuetype定义略 record/queuetype/ sq sq.front=MAXLEN sq.rear=MAXLEN end void InitQueue ( SeqQueue *Q ) { //构造空队列 Q-data=(QueueData*) malloc (MAXSIZE*sizeof(QueueData)); if(! Q-data) exit(OVERFLOW); Q-rear = Q-front = 0; return 1; } 循环队列的入队算法: parameter(MAXLEN=4) subroutine EnQueue(q, front,rear,x) integer front,rear datatype x,q(MAXLEN) if(mod(rear,MAXLEN)+1.eq. front) print*,’queue is full!’ else rear=mod(rear,MAXLEN)+1 q(rear)=x endif end 循环队列的入队算法: subroutine EnQueue(sq, x) parameter (MAXLEN=4) 结构体类型queuetype定义略 record/queuetype/ sq datatype x if(mod(sq.rear,MAXLEN)+1.eq. sq.front) print*,’queue is full!’ else sq.rear=mod(sq.rear,MAXLEN)+1 sq.q(sq.rear)=x endif end 循环队列的入队算法: int EnQueue ( SeqQueue *Q, QueueData x ) { if ((rear%MAXSIZE)+1 == front) {printf(“queue is full!); return(-1); } else {Q-rear=(Q-rear %MAXSIZE)+1 ;return 1;} } 循环队列的出队算法: function delqueue(sq) parameter (MAXLEN=4) 结构体类型queuetype定义略 record/queuetype/ sq datatype delqueue 假设datatype在此代表整型 if (sq.front.eq.sq.rear) print*,’stack is empty!’ delqueue=-1 else sq.front=mod(sq.front,MAXLEN)+1 delqueue=sq.q(sq.front) endif end 循环队列的出队算法: int DelQueue ( SeqQueue *Q, QueueData x ) { if (Q-rear == Q-front ) return
您可能关注的文档
最近下载
- 2025湖北武汉市汉阳区招聘社区干事40人备考试题及答案解析.docx VIP
- 新能源汽车试题库(附答案).docx VIP
- 《碳纤维片材加固混凝土结构技术规程》(2022年版).pdf VIP
- 2023年地面及屋面分布式光伏发电工程HSE作业指导书(最终版).docx VIP
- 常用塑料特性及塑料成型工艺.pdf VIP
- 甲烷安全技术说明书MSDS.pdf VIP
- 统编版语文四年级上册第五单元素养评估(含答案).docx VIP
- 入党志愿书电子版模板(空白) .doc VIP
- 五年级下册生字练字帖硬笔书法.pdf VIP
- 《国有企业管理人员处分条例》考试题库200题(含答案).docx VIP
文档评论(0)